知识大全 浅析PowerBuilder下动态SQL语句[1]
Posted 语句
篇首语:多练多乖,不练就呆。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 浅析PowerBuilder下动态SQL语句[1]相关的知识,希望对你有一定的参考价值。
浅析PowerBuilder下动态SQL语句[1] 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!
PowerBuilder是目前最流行的数据库开发工具之一 PowerBuilder提供了在程序代码中加入嵌入式SQL语句的功能来支持对数据库的访问 但这种嵌入式SQL语句只能支持一些固定的标准的SQL语句 即在进行程序代码编译处理时这些SQL语句必须是确定的 另外这种方式也不能执行像Creat Table Creat Database等这些数据库定义的语句(DDL)
因此这种嵌入式SQL语句在实际应用中有一定的局限性 为克服这种方式的局限性 可以使用PowerBuilder提供的动态SQL语句 这种对数据库访问的方式可以完成嵌入式SQL语句无法实现的功能 如建库 建表这一类的数据库定义语句(DDL) 其次 由于动态SQL语句允许在执行时才确定到底要执行怎样的SQL语句 因此使用动态SQL语句可以使程序实现参数化设计 具有很大的灵活性和通用性
一 动态SQL语句的应用分析 PowerBuilder提供了四种格式的动态SQL语句 每种格式都有自己不同的特点和作用
(一)第一种格式
当执行没有输入参数并且没有返回结果集的SQL语句时可以使用这种格式 这种格式使用比较简单 其实现的操作也比较少
语法
EXECUTE IMMEDIATE SQLStatementUSING TransactionObject;
其中SQLStatement是要执行的SQL语句 可以直接用引号将要执行的SQL引起来用 或者用字符串变量的形式提供SQL语句 通过使用字符串变量可以在具体执行的时候才指定要执行什么样的SQL语句 TransactionObject是用户所使用的事务对象 缺省为SQLCA
应用实例
①建立一张数据库表(base) SQL语句的表述用引号引起来直接使用
EXECUTE IMMEDIATE CREATE TABLE base(code char( ) name char( )) USING SQLCA;
②执行对数据库记录的操作 在表base中插入一条记录 SQL语句通过字符串变量传递执行语句
STRING lsSQL
LsSQL= INSERT INTO TABLE base VALUES( 市中区支行 )
EXECUTE IMMEDIATE:lsSQL;
(二)第二种格式
当执行带输入参数但没有返回结果集时的SQL语句可以采用第二种格式 该格式不仅可以动态地指定要执行的SQL语句 同时还可以动态地确定SQL语句所需要的参数值
语法
PREPARE DynamicStagingArea FROM SQLStatementUSING TransactionObject;
EXECUTE DynamicstagingAreaUSING Parameterlist;
其中 DynamicstagingArea是PowerBuilder提供的一种数据类型 PowerBuilder本身提供了一个名字为SQLSA的DynamicstagingArea类型的全局变量 用于保存要执行的动态SQL语句信息
应用实例
删除base表中的满足一定条件的记录
STRING lsCode
lsCode=
PREPARE SQLSA FROM DELETE base WHERE code=? ;
EXECUTE SQLSA USING:lsCode;
(三)第三种格式
当执行有输入参数并且返回结果集的格式在编译时可以确定的SQL语句时可以使用第三种格式 这种格式语法比较复杂 但要比前面两种功能强 可以返回结果集 在返回结果时由于不知道满足过滤条件的记录到底有多少条 因此第三种格式通常采用游标的形式
语法
DECLARE cursor DYNAMIC CURSOR FOR DynamicStagingArea;
PREPARE DynamicStagingArea FROM SQLStatementUSING TransactionObject;
OPEN DYNAMIC cursor USING Parameterlist;
FETCH cursor INTO VariableList;
CLOSE cursor;
其中cursor是用户所定义的游标的名字
应用实例
将表base中的code字段中间两位为 的所有记录读取出来并分别进行相应处理
STRING lsSQL lsCode lsName lsFilter
LsFilter=
LsSQL= SELECT code name FROM base WHERE substring(code )=?
DECLARE cursor_base DYNAMIC CURSOR FOR SQLSA;
PREPARE SQLSA FROM:lsSQL;
OPEN DYNAMIC cursor_base USING:lsFilter;
FETCH cursor_base INTO:lsCode :lsName;
DO WHILE SQLCA SQLCODE=
∥对满足条件的记录根据要求分别进行处理
FETCH cursor_base INTO:lsCode :lsName;
LOOP
CLOSE cursor_base;
cha138/Article/program/PB/201311/24649相关参考
在PB中动态修改SQL语句[1] 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! &nbs
用sql语句动态的创建access表的代如下! <% nowtime=now()tablename=cstr(year(nowtime))
在PB中动态修改SQL语句[2] 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! &nbs
知识大全 带参数动态执行sql语句:Execute Immediate
带参数动态执行sql语句:ExecuteImmediate 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一
LINQtoSQL语句之动态查询 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! LINQtoSQ
存储过程里动态生成包含SQL语句字符串 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 某些时候我
知识大全 为什么在使用动态 SQL 语句时必须为低层数据库对象授予权限
为什么在使用动态SQL语句时必须为低层数据库对象授予权限? 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一
在PowerBuilder中实现动态菜单的方法 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 曾
每次在操作数据库的时候最烦的就是根据表单提交的内容写sql语句特别是字段比较多的时候很麻烦动不动就容易写错所以我就写了下面的生成sql语句的函数用了用觉得还可以 程序代码 <%=====
知识大全 Powerbuilder 10.0应用程序发布及动态配置ODBC
Powerbuilder10.0应用程序发布及动态配置ODBC 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来