Oracle-自动生成insert、update、select、javabean语句
来源:互联网 发布:网络传输介质有哪些 编辑:程序博客网 时间:2024/05/17 07:42
首先把下面语句 在Oracle中执行一下
create or replace function my_concat(tableName varchar2,type varchar2)return varchar2is type typ_cursor is ref cursor; v_cursor typ_cursor; v_temp varchar2(30); v_result varchar2(4000):= ''; v_sql varchar2(200);begin v_sql := 'select COLUMN_NAME from user_tab_columns where table_name = ''' || upper(tableName) || ''' order by COLUMN_ID asc'; open v_cursor for v_sql; loop fetch v_cursor into v_temp; exit when v_cursor%notfound; if type = 'select' or type = 'insert' then v_result := v_result ||', ' || v_temp; elsif type = 'update' then v_result := v_result ||', ' || v_temp || ' = ?'; elsif type = 'javabean' then v_result := v_result ||',bean.get' || upper(substr(v_temp,1,1)) || lower(substr(v_temp,2)) || '()'; end if; end loop; return substr(v_result,2);end;create or replace procedure autoGenerateSQL(tableName varchar2,type varchar2,out_result out varchar2)is sql_insert varchar2(2000); sql_update varchar2(2000); sql_select varchar2(2000); javabean_str varchar2(2000); field_num integer; --字段个数 type_info varchar2(20); --参数类型判断信息beginsql_insert := 'INSERT INTO ' || upper(tableName) || '(' || my_concat(tableName,type) || ') VALUES (';sql_update := 'UPDATE ' || upper(tableName) || ' SET ';sql_select := 'SELECT ';javabean_str := '';type_info := '';select count(*) into field_num from user_tab_columns where table_name=upper(tableName);select decode(type,'insert',type,'update',type,'select',type,'javabean',type,'error') into type_info from dual;if field_num = 0 then -- 表不存在时 out_result := '表不存在!请重新输入!';elsif type_info = 'error' then --type参数错误时 out_result := 'type参数错误:参数必须小写,类型只能是insert、update、select、javabean之一';elsif field_num > 0 then if type = 'insert' then --生成insert 语句 for i in 1..field_num loop sql_insert := sql_insert || '?'; if i < field_num then sql_insert := sql_insert || ', '; end if; end loop; sql_insert := sql_insert || ')'; out_result := sql_insert; elsif type = 'update' then --生成update 语句 sql_update := sql_update || my_concat(tableName,type); out_result := sql_update; elsif type = 'select' then --生成select 语句 sql_select := sql_select || my_concat(tableName,type) || ' FROM ' || upper(tableName) || ' A'; out_result := sql_select; elsif type = 'javabean' then --生成javabean的get方法 javabean_str := my_concat(tableName,type); out_result := javabean_str; end if;end if;end autoGenerateSQL;
执行完后 会有一个函数,和一个存储过程
在存储过程哪里 右键 点击测试
填上表名和insert、update、select、javabean
就会生成相应的语句.
0 0
- Oracle-自动生成insert、update、select、javabean语句
- 使用Java生成insert,select,update语句
- 快速生成Insert、Update、Select语句
- 根据表名自动生成INSERT,UPDATE,DELETE,SELECT的SQL语句
- 根据表名自动生成INSERT,UPDATE,DELETE,SELECT的SQL语句
- 根据表名自动生成INSERT,UPDATE,DELETE,SELECT的SQL语句
- 根据表名自动生成INSERT,UPDATE,DELETE,SELECT的SQL语句
- CodeSmith自动生成Insert/Delete/Update/Select存储过程模板
- Oracle数据库自动生成insert语句
- 根据数据库自动生成INSERT/UPDATE更新语句
- oracle insert select语句
- select,delete,update,insert语句使用方法
- SQL语句复习:insert,update,delete,select
- SQL语句复习:insert,update,delete,select
- jpa 原生insert\delete\update\select语句
- jpa 原生insert\delete\update\select语句
- ORACLE:SELECT语句里调用函数使用DML语句进行UPDATE/INSERT/DELETE操作
- SQL语句:update---select,insert---select,select---into
- 2016年10月21日
- java 负数
- 使用CocoaPods做依赖管理
- hadoop ha 只能同时启动一个namenode问题的解决方案
- Uiautomator通过Uiautomator.Helper类控制台快速调试--小白快速上手
- Oracle-自动生成insert、update、select、javabean语句
- golang开发框架之gin
- 俄语IT词汇积累
- socket中tcp的断包、粘包处理方法
- spfa 有无负权环 负权边最短路 模板
- 第二十篇玩转【斗鱼直播APP】系列之“趣玩”界面展示
- model里面套model
- linux查看端口是否禁用和开启关闭端口
- 过滤器