SAP_DBCO连接外部数据库的方法

合集下载

JDBC连接数据库步骤流程

JDBC连接数据库步骤流程

JDBC连接数据库步骤流程JDBC(Java Database Connectivity)是Java语言操作数据库的一种标准API。

下面是JDBC连接数据库的步骤流程,包括导入所需的类、加载数据库驱动程序、建立数据库连接、执行SQL语句等。

1.导入所需的类在Java代码中,首先需要导入JDBC相关的类和接口。

通常会导入java.sql及javax.sql包中的类。

```javaimport java.sql.*;```2.加载数据库驱动程序在使用JDBC之前,需要预先加载适当的数据库驱动程序。

不同的数据库有不同的驱动程序,具体可以查看相应数据库的官方文档。

一般来说,数据库驱动程序是通过使用Class.forName(方法来加载的。

```java```3.建立数据库连接连接到数据库需要指定数据库的URL、用户名和密码。

首先需要创建一个Connection对象,然后使用DriverManager类的getConnection(方法来建立数据库连接。

```javaString url = "jdbc:mysql://localhost:3306/mydatabase";String username = "root";String password = "password";Connection conn = DriverManager.getConnection(url, username, password);```4.创建执行SQL语句的对象对数据库进行操作前,需要创建一个Statement或PreparedStatement对象。

Statement对象用于执行静态的SQL语句,而PreparedStatement对象用于执行动态的SQL语句,可以通过占位符传递参数。

```javaStatement stmt = conn.createStatement(;PreparedStatement pstmt = conn.prepareStatement("SELECT * FROM mytable WHERE id = ?");```5.执行SQL语句可以使用Statement的execute(、executeQuery(或executeUpdate(方法来执行SQL语句。

ASP连接数据库

ASP连接数据库
– Myrecordset用来存放返回数据的信息 Myrecordset用来存放返回数据的信息 – Commandtext:一个字符串,包含一个表名或某个将被执行的sql Commandtext:一个字符串,包含一个表名或某个将被执行的sql 语句 – Recordaffected:一个变量,返回此次操作所影响的记录数 Recordaffected:一个变量, – Options:指定command参数的性质 Options:指定command command参数的性质
• AdOpenForwardOnly(=0) 只读,且当前数据记录只能向 只读, 下移动 • AdOpenStatic(=3) 只读,当前数据记录可自由移动 只读, • AdOpenKeyset(=1) 可读写,当前数据记录可自由移动 可读写, • AdOpenDynamic(=2) 可读写,当前数据记录可自由移动 可读写, • AdOpenKeyset和AdOpenDynamic的差别只表现在多 和 的差别只表现在多 人共用数据库时,若以AdOpenKeyset 模式打开数据表, 模式打开数据表, 人共用数据库时,若以 则无法看到其他人新增的数据记录(除非重新启动), ),如 则无法看到其他人新增的数据记录(除非重新启动),如 果是以AdOpenDynamic模式打开数据库,则可以看到其 模式打开数据库, 果是以 模式打开数据库 他人新增的数据记录。 他人新增的数据记录。
–Open:打开一个基于ActiveConnection和 Open:打开一个基于ActiveConnection和 Open ActiveConnection source属性的 属性的recordset. source属性的recordset.
• Recordset.open[source],[activeconnection],[c ursortype],[locktype],[options]

sap数据批量导入教程、BDC实例详细讲解步骤

sap数据批量导入教程、BDC实例详细讲解步骤

SAP数据批量导入教程文章第59页第4部分为BDC批导入处理教程1.前言1.1.ECATT解释Extended Computer Aided Test Tool(T-code:SECATT)ECATT是SAP自带的功能测试工具,主要目标用来作SAP业务流程的自动化测试,每个测试都会生成一个详细的日志来显示测试流程和测试结果。

和CATT相比,CATT操作简单,类似于BDC的录屏功能,用于常用的简单业务数据导入,基本已被ECATT完全取代。

除了CATT功能之后,ECATT主要应用于基于GUI Windows/Gui Java自动化测试,同时也为外部工具提供了第三方接口(获BC-ECATT授权)。

所有的测试脚本,无论是ECATT自已生成的还是外部工具的他们都应该具有相同的数据对象类型,与SAP结合在一起并保存在相同的位置。

在R/3的功能测试中,ECATT录屏功能简单实用,测试脚本、测试数据、系统数据分别存放,可重复使用,并附有详细测试报告以及纠错功能,作为自带工具简单实用。

对于WEB方面的测试的话就要借用第三方的测试软件,如知名的Mercury的QTP。

1.2.LSMW解释Legacy System Migration Workbench (T-code: LSMW)LSMW, 是SAP推荐用来从旧的系统或非SAP系统把大批量或周期性的数据迁移到SAP的主力工具,类似于ECATT/SCATT,其优点可以在一个Session中处理大批量数据,并灵活易学易用。

如果用BDC 和ECATT只能根据定制好的画面输入参数。

一旦没有这个值系统就会报错。

比喻我们根据业务对FI Account Document或者主数据一些参数作了扩展,一旦参数缺失或者不匹配,不得不终止Session,通过SM35手动去更正或者重新录屏。

LSMW具有一般的通用性,他导入模板的设计过程包括15个步骤,每个都是独立的单元并可进行单独的更新和修改,而不影响其它的模块只需作一些调整做出相应mapping,将必要的数据指定对应的字段就可行了,无需额外的编码。

ABAP 访问外部数据库简明代码

ABAP 访问外部数据库简明代码

*& 需先在DBCO中建立连接池,网上都有,以下为代码*&---------------------------------------------------------------------**& Report Z_XXF_DB_TEST*&*&---------------------------------------------------------------------** 程序名称:** 作者: xxf* 开发日期:* 请求号:* 申请者y:* 功能/技术文档:* 描述:**** 变更记录** 修改日期开发人员请求号描述*&*&---------------------------------------------------------------------*report z_xxf_db_test.data: dbs type dbcon-con_name value 'TEST'.data: begin of wa_employees,id type i, "iddeptno(20) type c, "部门编号deptname(20) type c, "部门名称empid(10) type c, "员工编号empname(15) type c, " 员工姓名empcard(10) type c, " 员工卡号end of wa_employees.data: it_employees like table of wa_employees.data: g_flag type c.selection-screen begin of block blk4 with frame title text-001. parameters: g1 radiobutton group gr1 default 'X' user-command zus1, g2 radiobutton group gr1,g3 radiobutton group gr1,g4 radiobutton group gr1.selection-screen end of block blk4.start-of-selection.clear: g_flag.perform connect_mss. "链接数据库if g1 is not initial.elseif g2 is not initial.perform frm_insert_data.elseif g3 is not initial.perform frm_update_data.else.perform frm_del_data.endif.if g_flag is initial.perform frm_get_data.endif.perform disconnect_mss. "断开数据库*&---------------------------------------------------------------------* *& Form connect_mss*&---------------------------------------------------------------------* * text*----------------------------------------------------------------------* form connect_mss.EXEC SQL.connect to :dbsENDEXEC.EXEC SQL.set connection :dbsENDEXEC.if sy-subrc <> 0.raise exception type cx_sy_native_sql_error. endif.endform. "connect_mss*&---------------------------------------------------------------------* *& Form DISCONNECT_MSS*&---------------------------------------------------------------------* * textform disconnect_mss.EXEC SQL.DISCONNECT :dbsENDEXEC.endform. "DISCONNECT_MSS*&---------------------------------------------------------------------**& Form FRM_GET_DATA*&---------------------------------------------------------------------** text*----------------------------------------------------------------------** --> p1 text* <-- p2 text*----------------------------------------------------------------------*form frm_get_data .EXEC SQL PERFORMING appendemployees.select id,deptno,deptname,empid,empname,empcardinto :wa_employees from employeesENDEXEC."sql句尾不需要点loop at it_employees into wa_employees.write:wa_employees-id,wa_employees-deptno,wa_employees-deptname,wa_employees-empid,wa_e mployees-empname.clear: wa_employees.endloop.endform. " FRM_GET_DATA*&---------------------------------------------------------------------**& Form APPENDEMPLOYEES*&---------------------------------------------------------------------** text*----------------------------------------------------------------------** --> p1 text* <-- p2 text*----------------------------------------------------------------------*form appendemployees .append wa_employees to it_employees.clear wa_employees.endform. " APPENDEMPLOYEES*&---------------------------------------------------------------------**& Form FRM_INSERT_DATA*&---------------------------------------------------------------------** text* --> p1 text* <-- p2 text*----------------------------------------------------------------------*form frm_insert_data .EXEC SQL.insert into Employees (deptno,deptname,empid,empname,empcard,InJob_date,JoinJob_date,V1,empzwid) values ('01','xx公司','EMP2785','xuxiaofeng','1234567890','1900/01/01','1900/01/01',1,'') ENDEXEC.if sy-subrc = 0.commit work. "这个一定要的write: ' 执行成功!!。

【内部顾问技能收集】ABAP模块技能统计

【内部顾问技能收集】ABAP模块技能统计

【内部顾问技能收集】ABAP模块技能统计[复制]1. 姓名 [填空题] *_________________________________2. 工号 [填空题] *_________________________________请勾选您已熟练掌握的技能点,如不熟悉请保留空值。

3. 基础技能 [多选题]□DEBUG(能够熟练地进行利用关键字对字符串进行操作)□前台数据追踪(前台数据追踪的方法,如何查找标准程序,ST05跟踪程序)□字符串操作(能够熟练地进行利用关键字对字符串进行操作)4. 批处理开发 [多选题]□BDC开发(能够熟练使用SHDB录屏以及进行BDC批导开发)□BAPI(能够查找BAPI,并且使用BAPI完成批量操作的开发)5. ALV [多选题]□ALV的基础开发(简单的ALV开发)□ALV高级开发(自定义GUI状态栏按钮,ALV颜色设置,保存信息至内表)□ALV Tree (ALV树形开发)6. Smartforms [多选题]□SF基础开发(简单的SF开发)□SF中级开发(自定义样式,修改字体格式,颜色,大小)□SF高级开发(会在SF中编写代码,实现取数或者编辑样式,会自定义非标准的纸张格式)7. (Form) [多选题]□Form的基础开发(简单的Form开发)□Form中级开发(能在Form中通过语句控制输出流,实现不同条件的显示)□Form高级开发(通过调用外部程序,在Form中实现变量计算,调用外部文本元素)8. 屏幕开发 [多选题]□屏幕基础开发(能够使用向导创建TABLE control进行简单的数据显示)□屏幕中级开发(能够不适用向导独自创建table control,并且能够进行数据的增删改查)□屏幕高级开发(熟悉利用屏幕的各种控件进行屏幕开发)9. 增强 [多选题]□一代增强(SAP预留程序)□二代增强(SMOD,CMOD的USER-EXIT)□三代增强(BADI增强)□四代增强(ECC6后的ENHANCEMENT)□BAPI增强□BTE增强□Search Help增强10. 接口 [多选题]□I/F文件上下载(以文件形式进行传输方式实现)□RFC(外部系统调用 RFC函数实现)□IDOC(通过IDOC形式将数据文件发送进行交互)□DBCO(通过链接访问外部数据库的方式进行查询)□WEB Service (Web Service 和其他系统交互)11. 其他技能 [多选题]□Function的基础开发□自定义号码段范围□程序中实现表锁定或条目锁定□Query开发□逻辑数据库开发□OLE开发(能够使用OLE开发导出Excel或Word)□程序优化(能够对自开发程序进行报表速度/效率的优化)□WEB DYNPRO的开发□PI的配置及实现□银企直连(https,http,TCP/IP等协议的交互)□表格维护生成器(能够根据需要维护好表格维护生成器的状态(如自动带出日期,是否可编辑,是否显示等)□ADOBE报表(通过SFP开发展示报表)□数据归档开发。

用ASP连接各种数据库的方法(经典)

用ASP连接各种数据库的方法(经典)

用ASP连接DBF、DBC、MDB、Excel、SQL Server型数据库的方法2008-08-30 15:02一般来说,一个真正的、完整的站点是离不开数据库的,因为实际应用中,需要保存的数据很多,而且这些数据之间往往还有关联,利用数据库来管理这些数据,可以很方便的查询和更新。

数据库有很多种,如:Fox 数据库(.dbf)、Access 数据库(.mdb)、Informix、Oracle 和SQL Server 等等,在这里,我将以Microsoft Access 数据库为例来说明ASP是如何访问数据库的。

常用数据库语句1.SELECT 语句:命令数据库引擎从数据库里返回信息,作为一组记录。

2.INSERT INTO 语句:添加一个或多个记录至一个表。

3.UPDA TE 语句:创建更新查询来改变基于特定准则的指定表中的字段值。

4.DELETE 语句:创建一个删除查询把记录从FROM 子句列出并符合WHERE 子句的一个或更多的表中清除。

5.EXECUTE 语句:用于激活PROCEDURE(过程)用ASP 来做一个自己的通讯录练练手吧……一、建立数据库:用Microsoft Access 建立一个名为data.mdb 的空数据库,使用设计器创建一个新表。

输入以下几个字段:字段名称数据类型说明其它ID自动编号数据标识字段大小:长整型新值:递增索引:有(无重复)username文本姓名缺省值usermail文本E-mail缺省值view数字查看次数字段大小:长整型默认值:0索引:无indate时间日期加入时间缺省值保存为data.mdb 文件,为了便于说明,只是做了一个比较简单的库。

二、连接数据库方法1:Set conn = Server.CreateObject("ADODB.Connection")conn.Open "driver={Microsoft Access Driver(*.mdb)};dbq="&Server.MapPath("data.mdb")方法2:Set conn = Server.CreateObject("ADODB.Connection")conn.Open "Provider=Microsoft.Jet.OLEDB.4.0;DataSource="&Server.MapPath("data.mdb")注意:一个页面中,只要连接一次就可以了,数据库使用完后要及时关闭连接。

SAP-ABAP-BDC详细使用

SAP-ABAP-BDC详细使用

SAP-ABAP-BDC详细使用传输数据的过程1.2.3.4.获取要传输的数据(路径+文件名+格式)转换数据格式,使其成为系统可接受的格式(SenderStructure→ReceiverSructure)传输反馈BDC批导入是传递大批量数据到R/3的一项标准技术。

其模拟事务流程传递数据,数据就像在线输入一样进行传递。

该技术的优点是会执行事务的相关检查,因此可以保证数据的一致性。

批导入过程分为两步:1.创建一个批导入eion,其中包括所有相关的数据。

2.处理批导入eion,将其中包含的数据传入R/3系统。

数据传输工作台只执行第一步。

大多数SAP标准数据传输程序都使用的是批导入技术。

数据传输程序创建一个批导入eion,其在迟后一个时间处理。

批导入可以以多种方式执行:前台后台在处理过程中显示错误信息如果想对数据传输进行检查,可以在前台处理批导入或以显示错误信息的方式执行。

如果想传递数据或测试其性能,应该在后台处理。

特点分析简单地讲BDC就是先把相应事务的处理过程录制下来,然后让系统自动执行特定的事务过程,在执行的过程中把需要传输的数据输入进去。

所以可以看出BDC的优点是并不要求使用者对业务知识有多了解,只要相应的过程可以录制下来,就可以反复执行录制的过程,把数据输入系统。

但BDC有一个缺点,就是输入数据时,如果项目栏的记录很多而需要换页时,不同的程序可能换页方式不同,并且不同的显示器所显示的行项目数量也不一样多,会出现执行不下去或者遗漏数据的情况,这个问题比较棘手。

获取源数据一般情况下,在进行传输之前要把数据放入内表从系统内部获取例如,以ALV形式输出数据后此时,数据存放在与ALV控件相对应的内表中从系统外部获取CALLFUNCTION’DATA_UPLOAD’把数据由系统外部上传到ABP的内表中,这里的外部数据有严格的格式要求。

如果源数据是存放在E某CEL中,需要将其另存为以Tab键格开的文本文件。

JDBC连接数据库6个步骤

JDBC连接数据库6个步骤

JDBC连接数据库6个步骤JDBC(Java Database Connectivity)是Java语言连接数据库的一种标准API,它提供了一组用于访问和操作数据库的接口。

在使用JDBC 连接数据库时,一般需要经过以下6个步骤:1.加载数据库驱动程序:``````2.建立数据库连接:加载驱动程序后,需要获取一个数据库连接。

在JDBC中,可以通过DriverManager类的getConnection(方法来创建一个数据库连接对象。

该方法接受三个参数:数据库URL、用户名和密码。

数据库URL指定了要连接的数据库的位置和其他连接参数。

例如,如果要连接localhost上的名为test的MySQL数据库,可以使用如下代码:```String url = "jdbc:mysql://localhost:3306/test";String username = "root";String password = "password";Connection connection = DriverManager.getConnection(url, username, password);```3. 创建Statement对象:创建Statement对象用于执行SQL语句。

Statement是JDBC中用于发送静态SQL语句的对象。

可以通过调用Connection对象的createStatement(方法来创建一个Statement对象。

例如:```Statement statement = connection.createStatement(;```4.执行SQL语句:通过Statement对象的executeQuery(方法来执行SQL查询语句。

该方法返回一个ResultSet对象,用于保存查询结果。

例如,可以执行一个简单的查询语句并遍历结果集:```String sql = "SELECT * FROM students";ResultSet resultSet = statement.executeQuery(sql);while(resultSet.next()String name = resultSet.getString("name");int age = resultSet.getInt("age");//处理查询结果```除了executeQuery(方法,Statement对象还提供了其他执行SQL语句的方法,如executeUpdate(用于执行更新操作。

SAPDBCO连接外部数据库方法

SAPDBCO连接外部数据库方法

外部数据库的连接串示例(Tcode:DBCOSQL Server:DC Connection MYSQLDBMS mssUser saDB password z匚onir info MSSQL_SERVER=127,0.DAMSSQL_DeNAME^landahrrrPefrnanent FiConner tian Limit io nOptimum Conns0这里的连接信息很接近Sql Server的连接字符串,但是参数名略有不同。

指定主机IP、数据库名即可。

DB2连接信息看上去比较直接,分别是数据库名、端口号、主机IP地址Oracel :连接信息比较隐晦,必须在SAP应用服务器上安装Oracle Client ,然后设置连接,并在这里将连接信息指定与连接名一致。

为了防止乱码,我们还应该在链接信息后加如下参数:ZHS16GBK格式如下:ORCL.WORLD:ZHS16GBKMaxDBDB Connection HSPMaxDB是SAP自己的数据库,这个连接则是NetWeaver Developer版中默认创建的一个连接,其中的连接信息究竟代表什么,我也不甚清楚。

访问外部数据库2011年4月12日14:37实例:SAP系统访问PeopleSoft数据库*& ------------------------------------------------------------ &**&定义常量&**& ---------------------------------------------------------------------------------------------------- &*CONSTANT:S CNS_YGJK TYPE C LENGTH 10 VALUE 'HR9DEV'.** 打开连接EXEC SQL.CONNECT TO :CNS_YGJKENDEXE.C*** 获取人事数据TRY.EXEC SQL PERFORMINGPF_GET_RS.SELECT MANDT,ZID,OTYPE,INFTY,ZUPDATE,OPERA,ZDATAINTO :WA_HR01-MANDT,:WA_HR01-ZID,:WA_HR01-OTYPE,:WA_HR01-INFTY,:WA_HR01-ZUPDATE,:WA_HR01-OPERA,:WA_HR01-ZDATAFROM z00hrjzlch01WHERE SAP_GET = ''ENDEXE.C** 处理人事数据IF IT_HR01[] IS NOT INITIAL .LOOP AT IT_HR01 INTO WA_HR01.EXEC SQL.UPDATE z00hrjzlch01SET SAP_GET = 'X'WHERE MANDT = :WA_HR01-MANDTAND ZID = :WA_HR01-ZIDENDEXE.CIF SY-SUBRC = 0.********* 更新ERP数据库表EXEC SQL.COMMITENDEXECMODIFY Z00HRJZLCH01 FROM WA_HR01.COMMIT WORKENDIF.ENDLOOPENDIF.**关闭连接EXEC SQLDISCONNECT :CNS_YGJKENDEXEC**获取异常CATCH CX_SY_NATIVE_SQL_ERRORNTO CL_EXEC_REF. EXIT.CATCH CX_SQL_EXCEPTIONINTO CL_SQLERR_REF.EXIT.ENDTRY*&Form PF_GET_ZZ*& --------- **组织增量数据**FORM PF_GET_ZZ .APPEND WA_HR02 TO IT_HR02.ENDFORM " PF_GET_ZZ 事务代DBCO查看,SAP系统现存的码:程序中使用的是连接【HR9DEV.W0RLC】,双击这行如下图所示:先在SAP底层ORACLE数据库编辑TNS文件,一般由BASIS配置完成,配置路径:DIR_ORAHOME->network->admin->tnsnames.ora ;配置完成后我们可以用事务码:AL11查看配置是否正确,AL11查看连接【HR9DEV.WORLD具体配置DIR SETUPS1024 dOGadm 2010-11-2311:00:33oracle2320 d063dm 2011-03-0410:02:06tn&Fi3mes.0T3u sr/ sa p;D 0 6/ SYS/profileHR9DEV.WORLD =(DESCRIPTION =(ADDRESS LIST =(ADDRESS = (PROTOCOL = TCP) (HOST = 10. 15B. 252. 17) (PORT = 1521)) )(COliMECT.DATA =(SERVICE_ME = HR9DEV)在ABAE中链接字段:PERFORM CONNECT_MSS USING Test; " 接PERFORM DISCONNECT_DB USING T E吐:"断开。

ASP连接数据库的11种方法及相关语法★★★

ASP连接数据库的11种方法及相关语法★★★

ASP连接数据库的11种方法及相关语法编辑注:学会了这些东西,您将基本可以独立完成ASP对数据库的所有操作。

ASP连接数据库的11种方法——本文总结了使用ASP链接各种数据库的方法:1.Access数据库的DSN-less连接方法:set adocon=Server.Createobject("adodb.connection")adoconn.Open"Driver={Microsoft Access Driver(*.mdb)};DBQ="& _Server.MapPath("数据库所在路径")2.Access OLE DB连接方法:set adocon=Server.Createobject("adodb.connection")adocon.open"Provider=Microsoft.Jet.OLEDB.4.0;"& _"Data Source=" & Server.MapPath("数据库所在路径")3.SQL server连接方法:set adocon=server.createobject("adodb.recordset")adocon.Open"Driver={SQL Server};Server=(Local);UID=***;PWD=***;"& _"database=数据库名;"4.SQL server OLE DB连接方法:set adocon=Server.Createobject("adodb.connection")adocon.open"provider=SQLOLEDB.1;Data Source=RITANT4;"& _"user ID=***;Password=***;"& _"inital Catalog=数据库名"5.Oracle 连接方法:set adocon=Server.Createobject("adodb.connection")adocon.open"Driver={microsoft odbc fororacle};server=oraclesever.world;uid=admin;pwd=pass;"6.Oracle OLE DB 连接方法:set adocon=Server.Createobject("adodb.connection")adocon.open"Provider=OraOLEDB.Oracle;data source=dbname;userid=admin;password=pass;"7.dBase 连接方法:set adocon=Server.Createobject("adodb.connection")adocon.open"Driver={microsoft dbasedriver(*.dbf)};driverid=277;dbq=------------;"8.mySQL 连接方法:set adocon=Server.Createobject("adodb.connection")adocon.open"Driver={mysql};database=yourdatabase;uid=username;pwd=yourpassword;option=16386;"9.Visual Foxpro 连接方法:set adocon=Server.Createobject("adodb.connection")adocon.open"Driver={microsoft Visual Foxprodriver};sourcetype=DBC;sourceDB=*.dbc;Exclusive=No;"10.MS text 连接方法:set adocon=Server.Createobject("adodb.connection")adocon.open"Driver={microsoft text driver(*.txt; *.csv)};dbq=-----;"&_"extensions=asc,csv,tab,txt;Persist SecurityInfo=false;"11.MS text OLE DB 连接方法:set adocon=Server.Createobject("adodb.connection")adocon.open"Provider=microsof.jet.oledb.4.0;data source=your_path;"&_"Extended Properties'text;FMT=Delimited'"<二>常用的四种SQL命令:1.查询数据记录(Select)语法:Select 字段串行 From table Where 字段=内容例子:想从book表中找出作者为"cancer"的所有记录,SQL语句便如下:select * from book where author=’cancer’"*"是取出book表所有的字段,如查询的字段值为数字,则其后的"内容"便无须加上单引号,如是日期,则在Access中用(#)包括,而在SQL server中则用(’)包括,如:select * from book where id=1select * from book where pub_date=#2002-1-7# (Access)select * from book where pub_date=’2002-1-7’ (SQL Server)提示:日期函数to_date不是标准sql文,不是所有的数据库适用,所以大家在使用的时候要参考数据库具体语法另外如果是查询传入的变量,则如下:strau=request.form("author")strsql="select * from book where author=’"&strau&"’"如果查询的是数字,则:intID=request.form("id")strsql="select * from book where id="&intID在很多数据库中,如:oracle,上面的语句是可以写成:strsql="select * from book where id='"&intID&"'"但是字符型一定不能按照数字格式写,需要注意。

SAP系统与外部系统的三种接口形式

SAP系统与外部系统的三种接口形式

SAP系统与外部系统的三种接口形式SAP系统之所以能成为ERP产品的代名词,不仅仅是因为SAP系统己经集成了当今世界最强大的管理功能和最优秀的业务流程,也是因为SAP系统提供了一个功能较为完善的开放的开发平台,它提供的开发接口使得SAP系统能够得以更广泛的应用,能更大程度上满足不同企业的需求。

根据系统数据交换的方式以及读写数据的相对关系不同,可以将外部系统与SAP系统的接口形式分为:主动式,被动式和中间式,如下图所示。

1、主动式接口即外部系统将SAP系统所需的信息直接写入SAP系统的数据库中。

这种方式要求详细了解SAP 系统内部的数据库结构,并且SAP系统允许外部系统往里写数据(即有写的权限)。

一般来说,主动式接口形式需要对SAP系统的数据库结构很清楚,对SAP系统录入数据时需要进行哪些数据校验也要很清楚,同时也要遵循SAP系统的数据校验规范,将其所需的物料信息、产品信息、加工信息等一一写入SAP系统中,保证数据的准确性和有效性。

采用主动式接口形式的优点:外部系统与SAP系统中的信息同步性好。

但在安全性方面存在一定问题,如出现写数据冲突,即外部系统写数据到SAP系统的同时,SAP系统本身也在往数据库中写入数据。

对于SAP系统建议一般不要采用此种方式。

2、被动式接口被动式接口,即SAP系统从外部系统中读取所需的数据,将其写入自已的数据库中。

对于被动式又有两种方式:全被动式和半被动式。

.全被动式:外部系统完全公开其表达和存储信息的数据库结构,SAP系统读取信息时自行判断哪些信息是增加的,哪些是修改的,哪些己删除了。

.半被动式:外部系统除公开其数据库结构外,还提供一些握手信号单独存入握手信号表中,握手信息说明哪些信息作了更新,这样SAP系统在读取外部系统中的信息(如某物料更改信息)时,根据握手信号表来读取外部系统中已经发生更改的部分信息,不需要全部读一遍,这样可以提高接口处理的速度。

采用被动式接口形式的优点:外部系统与SAP系统的同步性也做得比较好,安全性方面也比主动式要好。

SAP BDC数据导入简介

SAP BDC数据导入简介

BDC数据导入简介在SAP项目实施过程中,批量导入数据主要有三种方法,包括LSMW、CATT、BDC.下面简单介绍以下BDC导入数据的操作方法。

关于BDC,我查询到两种叫法,一个是Batch input communication,另一个是Batch data conversion.但是不知道这两种叫法哪一个是正确的,或者都正确。

BDC的处理步骤分为四步,如下:1.录制BDC标准命令,即BDC模板,就是将在SAP系统中处理的步骤录制下来,然后保存为文本文件到本地。

2.制作数据收集的EXCEL文件,这个文件是数据的原文件,可以根据不同的数据转换方法来定义不同的格式。

3.数据转换,并将转换后的数据上载到SAP系统当中,数据转换的方法常用有4种,WORD邮件合并、SAP TOOL、EXCEL宏、ABAP程序,我介绍SAP TOOL的数据转换方法。

4.到批处理画面进行批处理。

注意:做好的模板,要在测试系统中反复测试后,才能到生产机进行批量导入执行,否则容易出现大量错误,如果是主数据,可以大部分删除,如果是业务数据,就只能冲销了。

举例:大港油田226系统中供水公司工作中心的导入。

操作步骤:一.录制BDC模板执行事务代码SHDB,进入如下界面。

点击new recording.1.在记录字段填写记录名,由自己指定,这里填写KING.2.在Transaction code字段输入要执行的事务代码,这个是工作中心的导入,因此填写IR01.填写完成后,点击Start recording开始录制。

录制的过程就是创建一个工作中心的过程,创建完一个工作中心后,点击保存,出现如下界面。

点击按钮,将BDC模板下载到本地,文件名为bdc_recording的文本文件。

新建一个EXCEL文件,将单元格的格式改文本格式,将bdc_recording文本文件中的内容复制到这个EXCEL当中,我们来查看bdc_recording文件的结构。

SAP调用外部数据库

SAP调用外部数据库

SAP调⽤外部数据库SAP 中可以通过配置数据库的链接,来完成从SAP链接到外部的数据库中进⾏处理数据,具体操作如下:1、先进⼊事务:DBCO,设置数据库链接。

进⼊该事务后,如果系统已经有配置过类似链接则会出现在如下画⾯中,如图1:(图1)2、在该配置中的难点在于您使⽤的服务器类型,sap中提供多种选择,如图2:(图2)3、说其是难点,是因为不同的数据库类型,在‘链接信息’这栏填写的内容格式是不⼀样的,重点说明MSS和ORA(因为我只⽤到了这两种);a)、SQL Server这⾥的连接信息很接近 Sql Server 的连接字符串,但是参数名略有不同。

指定主机IP、端⼝号、数据库名即可。

b)、Oraceloracel的链接信息⽐较隐晦,必须在 SAP 应⽤服务器上安装 Oracel client ,然后设置链接,再在这⾥的链接信息进⾏指定。

4、设置完事务DBCO后,就可以进⾏编写代码测试链接是否成功。

(注:任何数据库配置信息都存放在表DBCON中)测试代码:(也可以见附件)附件代码:1*&---------------------------------------------------------------------*2*& Report ZQIU_TEST463*&4*&---------------------------------------------------------------------*5*& 从SAP获取SRM中的数据6*& SRM的数据库为Oracel7*&---------------------------------------------------------------------*89REPORT zqiu_test46.1011TABLES dbcon.1213TYPES: BEGIN OF gs_asn,14 vendor_code(100) TYPE c,"供应商代码15 vendor_name(100) TYPE c,"供应商名称16 ship_date TYPE d,"发货⽇期17"creation_date TYPE d,"创建⽇期18 org_code(100) TYPE c,"公司代码19 item_code(30) TYPE c,"物料编码20 item_name(1000) TYPE c,"物料描述21"ship_quantity22 segment1(30) TYPE c,"订单号23 line_num(30) TYPE c,"⾏号24END OF gs_asn.2526DATA: gt_asn TYPE STANDARD TABLE OF gs_asn,27 gw_asn TYPE gs_asn.2829FIELD-SYMBOLS:<fs_asn> TYPE gs_asn.3031CONSTANTS p_connr TYPE dbcon-con_name VALUE 'ZDBC0002'.3233*TRY.34* EXEC SQL.35* CONNECT TO :p_connr36* ENDEXEC.37* EXEC SQL.38* SET CONNECTION :p_connr39* ENDEXEC.40*41* IF sy-subrc EQ 0.42* WRITE: / '连接成功!'.43* ELSE.44* WRITE: / '连接失败!'.45* ENDIF.46*ENDTRY.4748START-OF-SELECTION.49PERFORM frm_get_data.5051*&---------------------------------------------------------------------*52*& Form frm_get_data53*&---------------------------------------------------------------------*54* text55*----------------------------------------------------------------------*56FORM frm_get_data.57TRY.58EXEC SQL.59 connect to :p_connr60ENDEXEC.61EXEC SQL.62 set connection :p_connr63ENDEXEC.64EXEC SQL PERFORMING frm_get_lines.65 select a.vendor_code,66 a.vendor_name,67 a.ship_date,68 _code,69 b.item_code,70 b.item_name,71 b.segment1,72 b.line_num73 into :gw_asn-vendor_code,74 :gw_asn-vendor_name,75 :gw_asn-ship_date,76 :gw_asn-org_code,77 :gw_asn-item_code,78 :gw_asn-item_name,79 :gw_asn-segment1,80 :gw_asn-line_num81 from inv_asn_headers a inner join inv_asn_lines b on a.asn_header_id = b.asn_header_id82 where b.segment1 = '60036078'83and b.status = 'NEW'8485ENDEXEC.8687"关闭连接88EXEC SQL.89 DISCONNECT :p_connr90ENDEXEC.91ENDTRY.9293IF gt_asn IS NOT INITIAL.94WRITE:/ '获取数据成功!'.9596PERFORM frm_out_put.97ENDIF.9899ENDFORM. "frm_get_data100101102*&---------------------------------------------------------------------*103*& Form frm_get_lines104*&---------------------------------------------------------------------*105* text106*----------------------------------------------------------------------*107FORM frm_get_lines.108APPEND gw_asn TO gt_asn.109ENDFORM. "frm_get_lines110111112*&---------------------------------------------------------------------*113*& Form frm_out_put114*&---------------------------------------------------------------------*115* text116*----------------------------------------------------------------------*117FORM frm_out_put.118LOOP AT gt_asn ASSIGNING <fs_asn>.119WRITE: / <fs_asn>-vendor_code,<fs_asn>-vendor_name,<fs_asn>-ship_date,<fs_asn>-120121 org_code,<fs_asn>-item_code,<fs_asn>-item_name,<fs_asn>-segment1,<fs_asn>-line_num.122ENDLOOP.123ENDFORM. "frm_out_putView Code(注:该⽂是本⼈在实践中的结果,如果有什么不⾜与问题望⼤家能指出,谢谢!O(∩_∩)O~)。

JdbcOdbc连接数据库的方法

JdbcOdbc连接数据库的方法

JdbcOdbc连接数据库的方法创建数据源(ODBC):开始→控制面板→管理工具具→ODBC数据源→选到系统DNS选项→点击添加,出现下图,选择你的数据源类型,我这里选择的是SqlServer下面开始填写你的数据源名称,我这里是sqlodbc,描述随便写,服务器我这里是本机的,如果你的机子上注册着其它IP上的数据库,用它们也可以。

这里选择使用用户和密码登录,而不是WINDOWSNT验证。

下面这个比较重要,就是更改默认的数据库,这里就是asp连接后默认的数据库了,我这里选的是科讯的。

上面的填完以后一直下一步,最后测试一下,如果显示成功,再点完成,那么数据源就建立完成了。

最后在系统数据源里就是出现你刚才添加的那个数据源一:创建java文件aapackage ;importjava.sql.*;public class aa {privatefinalString dbDriver = "sun.jdbc.odbc.JdbcOdbcDriver"; private final String url = "jdbc:odbc:sqlodbc";private final String username = "sa";private final String pwd = "sa";private Connection conn = null;//加载数据库publicaa() {try {Class.forName(dbDriver);System.out.println("数据库加载成功");} catch (Exception e) {System.out.println("加载数据库失败");}}//创建数据库连接publicbooleancreatConnection() {try {conn = DriverManager.getConnection(url, username, pwd);conn.setAutoCommit(true);System.out.println("数据库连接成功");} catch (SQLException e) {e.getStackTrace();//System.out.println("数据库连接失败");}return true;}//数据库添加publicbooleanexecuteUpdate(String sql) {if (conn == null) {creatConnection();}try {Statement stmt = conn.createStatement();intiCount = stmt.executeUpdate(sql);System.out.println("操作成功,所影响的条数是:" + String.valueOf(iCount));return true;} catch (SQLException e) {return false;}}//对数据库的查询操作publicResultSetexecuteQuery(String sql) { ResultSetrs = null;try {if (conn == null) {creatConnection();}Statement stmt = conn.createStatement(); rs = stmt.executeQuery(sql);returnrs;} catch (Exception e) {}returnrs;}public void closeConnection() {if (conn == null) {try {conn.close();} catch (Exception e) { e.getStackTrace();}}}}二:创建javaBean文件bbpackage ;public class bb {private String sid;private String name;public String getName() {return name;}public void setName(String name) { = name;}public String getSid() {returnsid;}public void setSid(String sid) {this.sid = sid;}}三:创建jsp文件chaxun(实现查询功能)<%@page import="java.sql.*"%><%@page contentType="text/html" pageEncoding="gb2312"%> <jsp:directive.page import=".aa"></jsp:directive.page><html><head><title>JSP Page</title><%aa connection = new aa();String sql = "select * from 注册信息"; ResultSetrs = connection.executeQuery(sql);%></head><body><center><h3>数据库连接</h3><hr><table border="2"><tr><td align="center" bgcolor="silver"><font size="5">学号</font></td><td align="center" bgcolor="silver"><font size="5">姓名</font></td></tr><%try {while (rs.next()) { //实现While循环%><tr><td><%=rs.getString(1)%></td><td><%=rs.getString(2)%></td></tr><%}} catch (Exception e) {} finally {connection.closeConnection();}%></table></center></body></html>四:创建jsp文件add(实现增加功能)(1)Aad.jsp<%@page import="java.sql.*"%><%@page contentType="text/html" pageEncoding="gb2312"%> <jsp:directive.page import=".aa"></jsp:directive.page><html><head><title>JSP Page</title><%aa connection = new aa();String sql = "select * from 注册信息"; ResultSetrs = connection.executeQuery(sql);%></head><body><center><h2>数据库连接</h2><hr><form action="add_01.jsp" name="form1" method="post" id="form1"> <table border="2"><tr><td align="center" bgcolor="silver"><font size="5">学号</font></td> <td align="center" bgcolor="silver"><font size="5">姓名</font></td></tr><%try {while (rs.next()) {%><tr><td><%=rs.getString(1)%></td><td><%=rs.getString(2)%></td></tr><%}} catch (Exception e) {} finally { connection.closeConnection();}%><tr><td bgcolor="silver">学号:</td><td><input type="text" name="sid" id="sid"></td></tr><tr><td bgcolor="silver">姓名:</td><td><input type="text" name="name" id="name"></td></tr></table><input type="submit" name="Submit" value="增加"><input type="reset" name="Submit1" value="重置"></form></center></body></html>(2)add-01.jsp<%@page contentType="text/html" pageEncoding="gb2312"%><html><head><title>JSP Page</title></head><% request.setCharacterEncoding("gb2312");%><jsp:useBean id="dbBean" scope="page" class=".aa"/><body><%String sid = newString(request.getParameter("sid"));String name = new String(request.getParameter("name"));String sqlAdd = "insert into 注册信息values('" + sid + "','" + name + "')";dbBean.executeUpdate(sqlAdd);dbBean.closeConnection();response.sendRedirect("add.jsp");%></body></html>。

SAP跨系统数据调用

SAP跨系统数据调用

SAP跨系统调用开发方案跨系统数据调用,指的是能够在两个不同数据库间传递资料。

SAP跨系统调用就是指能够在Sap内读取、更改其他服务器的数据,或者在其他开发平台上处理SAP数据.一般存在两种情况:一、在SAP内通过ABAP语言访问其他数据库:a、连接原理(1)、配置连接信息,在SAP的DBCO创建的外部数据库连接,(2)、测试是否连接成功,执行连接(3)、通过abap语言访问或更改SAP以外的其他数据库内的数据(SQL)(4)、断开连接涉及内容:1. EXCE SQL语句的online help2. 关于SAP中MultiConnect的信息3.关于修改TNSNAMES.ORA文件的信息b、架构图c、优点和弊端1、可以在SAP内通过ABAP同时操作N个数据库,操作方便,简单。

2、在后台由BASIS人员配置数据库连接,安全性好,开发人员不需了解参数配置信息。

3、在访问数据时必须用NATIVE SQL,用法不够灵活。

二、其他开发平台内访问SAP系统内数据:a、原理(1)、在SAP内创建RFC FUNCTION.(function、BAPI)(2)、在其他开发工具(vb,vc,java,.net) 内配置连接信息。

(3)、调用RFC,通过RFC处理或访问SAP数据。

涉及内容:1. SAP RFC的讲解(RFC、BAPI)2.连接信息的配置(SAP GUID连接和WEB SERVICE连接)3. SAP RFC访问用户的权限管控b、架购图c、优点和弊端1、连接方便,在SAP不需做任何配置。

2、可以跨语言调用,在原有PC项目上,调用SAP内数据。

3、SAP数据量大时,访问速度效率不高,往往做定制程序。

2024版SAP数据批量导入教程与BDC实例详细讲解

2024版SAP数据批量导入教程与BDC实例详细讲解
数据转换
将Excel数据转换为SAP系统可识别的格式,如CSV或XML。
使用SAP标准工具
利用SAP提供的标准工具如LSMW(Legacy System Migration Workbench)或DXC(Data Exchange Connector)进行批量导入。
自定义程序开发
若标准工具无法满足需求,可开发自定义程序实现Excel到SAP的数据 导入。
脚本执行与监控 在目标系统中执行BDC脚本,监控数 据同步过程,确保数据准确性。
23
06 总结与展望
2024/1/27
24
关键知识点回顾
SAP数据批量导入的概念和重要性
批量导入是SAP系统中一种高效的数据输入方式,可以大大提高数据处理的效率和准确
性。
BDC(Batch Data Communicati…
保证数据准确性
减少人为错误,确保数据的完整性和准确性。
促பைடு நூலகம்业务连续性
支持定期或实时的数据更新,确保系统数据的实时性和一致性。
2024/1/27
7
SAP系统中的批量导入工具
BDC(Batch Data Communicati…
SAP提供的标准工具,用于批量导入数据。它允许用户创建事务脚本,模拟用户在前端
21
案例二
数据库连接
建立与源数据库的连接,确保能够访问物 料主数据。
数据转换
将提取的数据转换为SAP系统可识别的格 式。
2024/1/27
数据提取
从数据库中提取物料主数据,包括物料编 码、描述、计量单位等。
使用中间件
如需实现实时或定时数据同步,可考虑使 用中间件如SAP PI(Process Integration) 或第三方ETL工具。

用ASP连接数据库的几种方法

用ASP连接数据库的几种方法

用ASP连接数据库的几种方法用ASP连接DBF、DBC、MDB、Excel、SQL Server型数据库的方法:一、ASP的对象存取数据库方法在ASP中,用来存取数据库的对象统称ADO(Active Data Objects),主要含有三种对象:Connection、Recordset 、CommandConnection:负责打开或连接数据Recordset:负责存取数据表Command:负责对数据库执行行动查询命令二、连接各数据库的驱动程序连接各数据库可以使用驱动程序,也可以使用数据源,不过我建议大家使用驱动程序,因为使用驱动程序非常方便、简单,而使用数据源比较麻烦。

驱动程序适用数据库类型Microsoft.Jet.OLEDB.4.0 MdbMicrosoft Access Driver AccessMicrosoft dBase Driver DbaseMicrosoft Excel Driver ExcelMicrosoft Visual FoxPro Driver DbcSQLOLEDB.1 SQL srver7.0而我们在一般情况下使用Access的数据库比较多,在这里我建议大家连接Access数据库使用下面的方法:dim connset conn = server.createobject("adodb.connection")conn.open = "provider=microsoft.jet.oledb.4.0;" & "data source = " &server.mappath("../db/bbs.mdb")其中../db/bbs.mdb是你的数据库存放的相对路径!如果你的数据库和ASP文件在同一目录下,你只要这样写就可以了:dim connset conn = server.createobject("adodb.connection")conn.open = "provider=microsoft.jet.oledb.4.0;" & "data source = " & server.map path("bbs.mdb")有许多初学者在遇到数据库连接时总是会出问题,然而使用上面的驱动程序只要你的数据库路径选对了就不会出问题了ASP连接数据库的5种方法第一种 - 这种方法用在ACCESS中最多strconn = "DRIVER=Microsoft Access Driver (*.mdb);DBQ=" _& Server.MapPath("aspfree.mdb")set conn = server.createobject("adodb.connection")conn.open strconn第二种-这种方法用在SQL SERVER中多strconn = "Driver={SQL Server};Description=sqldemo;SERVER=127.0.0.1;" _ &"UID=LoginID;Password=;DATABASE=Database_Name"set conn = server.createobject("adodb.connection")conn.open strconn第三种strconn="Driver={Microsoft Access Driver(*.mdb)};" _&"DBQ=F:\Inetpub\wwwroot\somedir\db1.mdb;DefaultDir=" _&"f:\Inetpub\wwwroot\somedir;uid=LoginID;" _&"pwd=Password;DriverId=25;FIL=MSAccess;"set conn = server.createobject("adodb.connection")conn.open strconn第四种运用系统数据源The following uses a Data Source Name: Exampleset conn = server.createobject("adodb.connection")conn.open "Example"第五种运用ODBC数据源,前提是你必须在控制面板的ODBC中设置数据源set rs = server.createobject("adodb.recordset")rs.open "tblname", "DSNName", 3, 3 第一种 - 这种方法用在ACCESS中最多strconn = "DRIVER=Microsoft Access Driver (*.mdb);DBQ=" _& Server.MapPath("aspfree.mdb")set conn = server.createobject("adodb.connection")conn.open strconnASP访问数据库的方式有哪些?在ASP中可以通过三种方式访问数据库:1、IDC(Internet Database Connector)方式;2、ADO(ActiveX Data Objects)方式;3、RDS(Remote Data Service)方式。

如何通过ABAP程序连接外部数据库

如何通过ABAP程序连接外部数据库

如何通过ABAP程序连接外部数据库(ORACLE)作者:侯志宇日期:2007-5-26一、基础系统配置在SAP 的应用服务器上需要设置连接外部数据库的配置,要求外部数据库的ORACLE AGENT 已经启动。

用Enterprise Manager Console 管理器建立连接数据库的资源即可,连通后进行下面的动作。

二、在SAP中设置连接1、输入事务代码:DBCO,新建一个连接池,操作如下所示;单击新建按钮新建一个条目,显示如下图:连接名:输入连接池的名字;DBMS:选择要连接的数据库类型(这里以oracel为例);用户名称:输入要连接的数据的用户名;数据库口令:输入要连接的数据的用户口令;连接信息:这对不同的数据库写法不一样,这里列举ORA数据库的写法;TEST_10.70.10.54,其中TEST是ora数据库的SID;Permanent:连接方式(是否是永久连接);输入完成后单击保存;三、连接成功后,下面是在ABAP中代码的写法;*--定义变量,注意:在用native SQL调用外部数据库时,定义变量不需要写类型;data :begin of WA,A(100),B(100),C(100),end of WA.*---------连接外部数据,固定写法------------------try.exec sql.CONNECT TO 'ORA54'endexec.exec sql.SET CONNECTION 'ORA54'endexec.catch CX_SY_NA TIVE_SQL_ERROR.write 'FALLUSE'.endtry.*-----------连接成功后执行sql------------------------*----执行查询语句的写法,LOOP_OUT是循环把取得的值输出;exec sql performing LOOP_OUT.SELECT A ,B , C INTO :W A FROM TESTendexec.*&--------------------------------------------------------------------**& Form LOOP_OUT*&--------------------------------------------------------------------** 输出*---------------------------------------------------------------------*form LOOP_OUT.write: / WA-A ,WA-B , WA-C.endform. "LOOP_OUT*------执行更新、查询、删除、插入语句的写法------------exec sql.*-----------更新语句----UPDATE TESTSET A = 'JKJKJKJKJJ'WHERE C = 3*--------查询语句---------DELETE TESTWHERE C = 0*-----------删除语句------INSERT INTO TEST V ALUES ('aaaaaa','BBBBBB',100)endexec.*----如何判断执行的sql语句成功与否------*---执行sql语句exec sql.DELETE SAP_TESTendexec.*--判断上面的数据是否成功-----IF SY-SUBRC = 0.WRITE:/ 执行成功!!。

sap连接oracle

sap连接oracle

SAP连接外部ORACLE数据库发表人:gjh3140 | 发表时间: 2007年十二月18日, 15:181.先在SAP底层ORACLE数据库编辑TNS文件,一般由BASIS配置完成.配置完成后我们可以用事务码:AL11查看配置是否正确,路径:DIR_ORAHOME->network->admin->tnsnames.ora查看对应的TNS是否配置正确,如:MDORA92.WORLD=(DESCRIPTION =(ADDRESS_LIST =(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.81.2) (PORT = 1521)))(CONNECT_DATA =(SID = mdora92)(SERVER = DEDICA TED)))2.在SAP中用DBCO配置,如下:在连接信息中加入MDORA92.WORLD为底层配置的名称,:ZHS16GBK是为了避免产生乱码3.编写程序实现SAP访问外部ORACLE数据库,下面的例子是个连接外部数据库过程:REPORT ZMM_BFS_DATABASE_CONNECT.INCLUDE <icon>.************************************************************************* Parameters and Select Options************************************************************************PARAMETERS:CON_NAME TYPE DBCON-CON_NAME OBLIGATORY.************************************************************************* Global variables************************************************************************DA TA:SQLERR_REF TYPE REF TO CX_SQL_EXCEPTION,CON_REF TYPE REF TO CL_SQL_CONNECTION,DEV_FILE(10) TYPE C.************************************************************************ START-OF-SELECTION.************************************************************************ TRY.CON_REF = CL_SQL_CONNECTION=>GET_CONNECTION( CON_NAME ).CA TCH CX_SQL_EXCEPTION INTO SQLERR_REF.WRITE:'无法打开数据库连接,连接名:', CON_NAME, '.'.IF SQLERR_REF->UNKNOWN_CONNECTION = 'X'.WRITE:/ CON_NAME, '没有定义在表DBCON,请用事务DBCO维护'.ELSEIF SQLERR_REF->DB_ERROR = 'X'.WRITE:/ 'SQL ERROR', SQLERR_REF->SQL_CODE, 'OCCURED:',/ SQLERR_REF->SQL_MESSAGE.ELSE.PERFORM GET_TRACE_FILE USING DEV_FILE.WRITE:/ 'DBI ERROR', SQLERR_REF->INTERNAL_ERROR, 'OCCURED.',/ 'SEE TRACE FILE FOR FURTHER INFO:',ICON_READ_FILE AS ICON HOTSPOT, DEV_FILE.ENDIF.RETURN.ENDTRY.WRITE:/ CON_NAME, '成功连接'.CON_REF->CLOSE( ).************************************************************************ END-OF-SELECTION.************************************************************************************************************************************************AT LINE-SELECTION.************************************************************************ * Display the trace fileIF NOT DEV_FILE IS INITIAL.CALL FUNCTION 'STRC_DISPLAY_WP_TRACE'EXPORTINGFILE = DEV_FILEEXCEPTIONSOTHERS = 4.ENDIF.*&---------------------------------------------------------------------**& Form GET_TRACE_FILE*&---------------------------------------------------------------------** text*----------------------------------------------------------------------* * -->P_DEV_FILE text*----------------------------------------------------------------------* FORM GET_TRACE_FILE USING P_DEV_FILE TYPE C.DA TA:WP_NO TYPE WPINFO-WP_NO.* get the number of the current WP and append it to 'dev_w' P_DEV_FILE = 'DEV_W'.CALL FUNCTION 'TH_GET_OWN_WP_NO' IMPORTINGWP_NO = WP_NO.P_DEV_FILE+5 = WP_NO.ENDFORM. "get_trace_file。

ASP连接数据库的种方法

ASP连接数据库的种方法

ASP连接数据库的种方法1.使用A连接对象:ASP可以使用A连接对象连接数据库,其中A代表了不同的对象类型,比如ADODB.Connection、ADODB.Recordset等。

这是最常见的连接数据库的方法之一2.使用ODBC连接:ASP支持通过ODBC(Open Database Connectivity)连接数据库。

ODBC是一种标准接口,可以连接不同类型的数据库。

使用ODBC连接数据库需要先创建一个数据源,然后通过数据源名称连接数据库。

3.使用DSN连接:DSN(Data Source Name)是ODBC的一种连接方式,在ASP中可以使用DSN连接数据库。

DSN是一种定义了数据库连接属性的文件,ASP可以使用该文件中的连接信息连接数据库。

4. 使用DSN-less连接:DSN-less连接是指不依赖DSN来连接数据库,而是直接使用连接字符串来连接数据库。

连接字符串包括了数据库的连接属性,如服务器地址、数据库名称、用户名、密码等。

5.使用连接池连接:连接池是一种连接数据库的技术,它利用缓存的连接对象提高数据库连接的性能。

ASP可以使用连接池来连接数据库,提高数据库查询操作的效率。

6.使用DSO连接:DSO(Data Shaping Object)是一种用于连接数据库的COM对象,可以使用它来连接数据库并执行查询操作。

DSO可以通过执行SQL语句或者使用分页功能,方便地进行数据库操作。

7. 使用Excel连接:ASP可以连接Excel文件作为数据库,利用Excel的数据存储和查询功能。

可以通过ADO连接Excel文件,并执行查询操作。

8. 使用Access连接:ASP可以连接Access数据库,Access是一个轻量级的数据库管理系统,支持SQL语言和ODBC连接。

可以通过ADO连接Access数据库,并进行增删改查等操作。

9. 使用SQL Server连接:ASP可以连接Microsoft SQL Server数据库,SQL Server是一种关系型数据库管理系统。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

外部数据库的连接串示例(Tcode:DBCO)
SQL Server:
这里的连接信息很接近 Sql Server 的连接字符串,但是参数名略有不同。

指定主机IP、数据库名即可。

DB2:
连接信息看上去比较直接,分别是数据库名、端口号、主机IP地址。

Oracel:
连接信息比较隐晦,必须在 SAP 应用服务器上安装 Oracle Client,然后设置连接,并在这里将连接信息指定与连接名一致。

为了防止乱码,我们还应该在链接信息后加如下参数:ZHS16GBK
格式如下:ORCL.WORLD:ZHS16GBK
MaxDB:
MaxDB 是 SAP 自己的数据库,这个连接则是 NetWeaver Developer 版中默认创建的一个连接,其中的连接信息究竟代表什么,我也不甚清楚。

访问外部数据库
2011年4月12日
14:37
实例:SAP系统访问PeopleSoft数据库
*&----------------------------------------------------------------------------------------------------- &*
*& 定义常

&*
*&------------------------------------------------------------------------------------------------------&*
CONSTANTS: CNS_YGJK TYPE C LENGTH 10VALUE'HR9DEV'.
**打开连接
EXEC SQL.
CONNECT TO :CNS_YGJK
ENDEXEC.
***获取人事数据
TRY.
EXEC SQL PERFORMING PF_GET_RS.
SELECT MANDT,
ZID,
OTYPE,
INFTY,
ZUPDATE,
OPERA,
ZDATA
INTO :WA_HR01-MANDT,
:WA_HR01-ZID,
:WA_HR01-OTYPE,
:WA_HR01-INFTY,
:WA_HR01-ZUPDATE,
:WA_HR01-OPERA,
:WA_HR01-ZDATA
FROM z00hrjzlch01
WHERE SAP_GET = ''
ENDEXEC.
**处理人事数据
IF IT_HR01[] IS NOT INITIAL.
LOOP AT IT_HR01 INTO WA_HR01.
EXEC SQL.
UPDATE z00hrjzlch01
SET SAP_GET = 'X'
WHERE MANDT = :WA_HR01-MANDT
AND ZID = :WA_HR01-ZID
ENDEXEC.
IF SY-SUBRC = 0.
*********更新ERP数据库表
EXEC SQL.
COMMIT
ENDEXEC.
MODIFY Z00HRJZLCH01 FROM WA_HR01.
COMMIT WORK.
ENDIF.
ENDLOOP.
ENDIF.
**关闭连接
EXEC SQL.
DISCONNECT :CNS_YGJK
ENDEXEC.
**获取异常
CATCH CX_SY_NATIVE_SQL_ERROR INTO CL_EXEC_REF.
EXIT.
CATCH CX_SQL_EXCEPTION INTO CL_SQLERR_REF.
EXIT.
ENDTRY.
*&---------------------------------------------------------------------*
*& Form PF_GET_ZZ
*&---------------------------------------------------------------------*
* 组织增量数据
*----------------------------------------------------------------------*
FORM PF_GET_ZZ .
APPEND WA_HR02 TO IT_HR02.
ENDFORM. " PF_GET_ZZ
事务代码:DBCO查看,SAP系统现存的连接
程序中使用的是连接【HR9DEV.WORLD】,双击这行如下图所示:
先在SAP底层ORACLE数据库编辑TNS文件,一般由BASIS配置完成,配置路
径:DIR_ORAHOME->network->admin->tnsnames.ora;配置完成后我们可以用事务
码:AL11查看配置是否正确,
A L11查看连接【HR9DEV.WORLD】具体配置。

相关文档
最新文档