oracle存储过程中如何执行动态SQL语句,详细?
有时需要在oracle存储过程中执行动态SQL语句,例如表名是动态的,或字段是动态的, 或查询命令是动态的,可用下面的方法: setserveroutputondeclarennumber;sql_stmtvarchar2(50); tvarchar2(20);beginexecuteimmediate'altersessionsetnls_date_format=''YYYYMMDD'''; t:='t_'||sysdate; sql_stmt:='selectcount(*)from'||t; executeimmediatesql_stmtinton; dbms_output.put_line('Thenumberofrowsof'||t||'is'||n);end; 如果动态SQL语句很长很复杂,则可用包装. CREATEORREPLACEPACKAGEtest_pkgISTYPEcur_typISREFCURSOR; PROCEDUREtest_proc(v_tableVARCHAR2,t_curOUTcur_typ);END;/ CREATEORREPLACEPACKAGEBODYtest_pkgISPROCEDUREtest_proc(v_tableVARCHAR2,t_curOUTcur_typ)ISsqlstrVARCHAR2(2000);BEGINsqlstr:='SELECT*FROM'||v_table; OPENt_curFORsqlstr;END;END;/ 在oracle中批量导入,导出和删除表名以某些字符开头的表 spoolc:\a.sql
mysql为何动态sql太长不能执行?
任何数据库的配置文件里面都会设置最大限制,超过限制语句就会被截断导致出错。
Mysql为例,在其配置文件中有一个设置 max_allowed_packet = 1M 此时如果你的SQL长度超过了1M就会被截断,从而导致执行失败
java用sql语句动态的往表里面添加字段,之后怎么能动态的读写新字段的数据?
用SQL语句添加表字段:alter table 表名add 字段名 字段类型;
用select name from syscolumns where id=object_id(表名)查找出所有的表字段。然后再使用SELECT 查找到的字段 from 表名。
使用ResultSet动态读取数据库数据。ResultSet 是一个迭代模式的动态连接容器。迭代模式的容器遍历方式:
图片来源:网络
while(rs.next()){
//循环内容
}
rs.next()返回值是一个布尔值,表示迭代容器中是否还有下一条数据,即在迭代过程中是否已经到结尾。直到迭代集合中再无数据rs.next()返回false;
怎么在程序中用动态sql语句创建视图?
试试这个方法:
stringMysqlMysql = "CREATE TABLE Employee "&
+"(emp_id integer not null,"&
+"dept_id integer not null, "&
+"emp_fname char(10) not null, "&
+"emp_lname char(20) not null)"
EXECUTE IMMEDIATE :Mysql USING SQLCA;