什么提供应用程序与数据库的接口

什么提供应用程序与数据库的接口,第1张

DBMS提供应用程序与数据库的接口。

DBMS提供应用程序与数据库的接口,允许用户逻辑地访问数据库中的数据,负责逻辑数据与物理地址间的映射,是控制和管理数据库运行的工具。

一个结构化的相关数据的集合。主要是通过综合汇总各个数据库用户的文件,除去不必要的冗余,然后使各个文件的数据项相互联系,从而形成整体数据结构。联系是数据库的重要特点,至于怎样实现这种联系,取决于数据库类型,类型不同。

联系手段也不一样,这个问题在第二章详细讨论。数据库是集成化的,能为多种应用服务,它独立于应用程序,是数据处理系统的核心和管理对象。

PowerBuilder(PB)和Oracle分别是前端开发工具和RDBMS的主流产品 PB提供了两种与Oracle连接的接口 PowerSoft内置的数据库接口(Native Database Interface)和ODBC接口

PowerBuilder与Oracle的连接

假定已安装Oracle客户端应用程序 可用Sqlplus或Tnsping等是否能连接到Oracle数据库 确定在SQLNET配置文件中使用的数据库别名(Database Alias 又称服务器名 Server Name) 如有疑问 可在Oracle客户端程序目录下tnsname ora文件中找到 另外保证搜索路径已包括SQLNET应用程序的安装目录(如C:\ORAWIN \BIN)

进入PB的Database Profiles画笔 可看到所有已安装的数据库接口(PB 缺省安装的是Oracle 版的接口 如使用低版本的Oracle 需在安装时指定) 选择 O Oracle 点击 New 按钮 进入Database Profile Setup对话框 在 Connection 页输入下列信息 Profile Name:为该Database Profile起一个有意义的名称 Server:@TNS:ServerName 其中ServerName为上述数据库别名(服务器名) 如@TNS:ORA ;注意 PB 则没有前面那个@TNS:!!!

Login ID:Oracle数据库中实际的用户名 由于PB初次连接到数据库时要自动建立五个系统表(PowerBuilder Catalog Table:PBCATTBL PBCATCOL PBCATEDT PBCATFMT PBCATVLD 存储表的扩展属性) 因此第一个连接到Oracle的用户必须具有建表 给PUBLIC角色授权等权限 例如可用SYSTEM用户进行第一次连接 此后的连接对用户则无特殊要求

Password:该用户的口令

设置上述内容后 即可连上Oracle 为优化数据库连接 还可设置下列选项

Prompt for Database Information:连接时是否提示用户输入用户名和口令

Generate Trace:启动DB跟踪工具 跟踪连接

Thread Safe:开发需要多线程环境支持的分布式应用时 选择该项 缺省为未选 适用于非分布应用

PBDBMS:与存储过程调用方式有关的参数 Oracle为 或更高版本时 清除该选项 此时带IN OUT参数的存储过程可作为数据窗口数据源 版本以下 选择该项 调用PBDBMS Put Line建立存储过程的SQL语句 缺省是选中

Commit on Disconnect:断开连接时 指定提交或回退未提交的事务

Case Sensitive:连接的Oracle服务器是否区分大小写 注意该项选中时 所有主键 包含主键的表名 外键须全为大写字符

PowerBuilder Catalog Tables Owner:指定拥有PB系统表的用户 缺省为 SYSTEM 如果要使用多种显示格式或有效性规则 可以在不同的用户下建立几套系统表

Table Criteria:指定满足哪些条件的表 视图和同义词可在 Select Tables 对话框中显示出来 例如DEV用户下销售子系统的表都以SALE开头 则可以用SALE% DEV TABLE VIEW 指定只显示DEV用户以SALE开头的表和视图

Asynchronous:选择该项 可在一个复杂的SQL语句执行过程中 返回第一行结果前 切换到其他 *** 作

Number of Seconds to Wait:若上一项选中 还可进一步通过该项指定检索数据时 等待数据库响应的时间

Retrieve Blocking Factor:决定数据窗口对象一次可从数据库取出的记录数

Number of SQL Staments Cached:PB可将数据窗口对象产生的SQL语句和嵌入式SQL语句保存在SQL语句缓冲区 该参数指定缓冲区为PB保留的SQL语句数目 该数值可由下式计算 SQLCache=服务器OPEN CURSORS数 (保留的游标数) 本连接预期使用的最大游标数

Disable Bind:指定是否将输入变量与SQL语句绑定 此参数影响PB为数据窗口对象生成INSERT语句的方式

Static Bind:数据窗口对象检索数据前是否检测SELECT语句的合法性

在Syntax页 还可指定日期 时间的格式等 在Preview页可查看Database Profile设置对应的PowerScript写法

Oracle存储过程的使用

归纳起来PB 中调用Oracle存储过程有以下四种方法

方法一 以关键字RPCFUNC声明存储过程

方法二 以DECLARE PROCEDURE语句声明存储过程

方法三 以动态SQL语句实现

方法四 调用函数PBDBMS Put Line

一般情况下 方法一能得到较好的运行效率和更完善的功能 因此推荐使用方法一 但是某些类型的存储过程只能使用其他方法 以下重点介绍方法一和方法二

两种方法比较起来 有以下几点主要区别

)方法一适用于具有IN OUT和IN OUT参数的存储过程 而方法二仅支持IN和OUT参数 不支持IN OUT参数

)方法一对参数的数目无限制 方法二最多支持 个参数

)方法一不支持记录(Recorder)的传递 方法二可传递和接收记录

方法一 *** 作步骤

)在用户对象画笔中创建一个Class Standard类型的 从Transaction继承的用户对象

)在此用户对象中 声明Local External Functions 将存储过程以RPCFUNC关键字声明为外部函数 在Declare Local External Functions对话框中按Procedures按钮选择要调用的后台存储过程 或直接输入类似subroutine TEST(long id ref string name)RPCFUNC ALIAS FOR DEVTEST 的语句 例如DEVTEST的参数为(id IN NUMBER name IN OUT VARCHAR )

)保存该用户对象

)在Application画笔中 进入应用属性对话框 在Variable Types页 将上Transaction用户对象设置为缺省的全局变量SQLCA

)脚本中 编码调用相应的外部函数 形式 SQLCA函数名(参数) 如可用 SQLCATEST(ln id ls name) 调用例子中定义的DEVTEST存储过程 其中ln id ls name为调用参数

方法一注意事项

)由于PB中String类型的数据长度是动态分配的 因此对Ref String类型的参数 每次调用前需要申请足够的空间 例如上例从输入的id值检索name 后台声明的NAME数据类型为VARCHAR ( ) 每次调用SQLCATEST前需要用ls name=SPACE( )置ls name为足够长度的空串

lishixinzhi/Article/program/PB/201311/24641

你说的是附加数据库吧

SQL Server提供了“分离/附加”数据库、“备份/还原”数据库、复制数据库等多种数据库的备份和恢复方法。“分离/附加”方法,类似于大家熟悉的“文件拷贝”方法,即把数据库文件(MDF)和对应的日志文件(LDF)拷贝到其它磁盘上作备份,然后把这两个文件再拷贝到任何需要这个数据库的系统之中。比如,在实验教学过程中,同学们常常想把自己在学校实验室计算机中创建的数据库搬迁到自己的计算机中而不想重新创建该数据库,就可以使用这种简单的方法。但由于数据库管理系统的特殊性,需要利用SQL Server提供的工具才能完成以上工作,而直接的文件拷贝是行不通的。

使用的SystemXml;

类计划

{

静态无效的主要(字符串[] ARGS)

{

XmlDocument的使用系统; DOC =新的XmlDocument();

docLoad(@“C:\ applicationconfig”);

XmlNode的测试docDocumentElement

XmlNodeList中了NodeList = NULL;

了NodeList = docSelectSingleNode(“配置/ /数据库/ /连接”)。的ChildNodes;

/ /遍历所有子节点

的foreach(XmlNode的NodeList中的XN)

{

了ConsoleWriteline(xnInnerText);

}

}

}打破;

以上就是关于什么提供应用程序与数据库的接口全部的内容,包括:什么提供应用程序与数据库的接口、PB内置Oracle数据库接口的使用方法[1]、MS SQL数据库,直接附加接口。是什么意思。等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9738740.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-01
下一篇2023-05-01

发表评论

登录后才能评论

评论列表(0条)

    保存