1.生成一个表的简单sql语句

CREATE OR REPLACE PROCEDURE proc_AutoGenerateSQL
(
  tableName   VARCHAR2 ,--参数 需要操作的表名 大小写区别
  tableType   NUMBER , --  参数  对表操作类型  0 =insert 1 =update 2=select
  sqlOrNet    NUMBER  ,-- 参数 需要生成那种格式sql 1 = sql  0  =net
  tableOutStr OUT VARCHAR2 --参数 输出需要的sql
)
IS
    sql_columns VARCHAR2(2000);
    sql_columnvalues VARCHAR2(2000);
  BEGIN
      BEGIN
        DECLARE
           CURSOR  c_t IS
           SELECT   column_id, column_name, data_type
           FROM user_tab_columns where table_name = ''||tableName||'' order by column_id;
           c_r  c_t%ROWTYPE;
           --开始游标创建需要列和值
                     BEGIN
           OPEN c_t;
           LOOP
           FETCH c_t INTO c_r;
           EXIT WHEN c_t%NOTFOUND;
                   IF  sql_columns<>' ' THEN
                                BEGIN
                                      --sql_columns := sql_columns||','||c_r.column_name;
                              IF c_r.data_type = 'DATE' THEN
                       IF  tableType =1 THEN  -- update
                           IF sqlOrNet = 1 THEN   --1 sql  0 net
                                sql_columns :=sql_columns||','||c_r.column_name||'='||''''||to_char(SYSDATE,'yyyy-MM-dd HH:mm:ss')||'''';
                           ELSE
                                sql_columns :=sql_columns||','||c_r.column_name||'=:'||c_r.column_name;
                           END IF;
                       ELSE
                                                sql_columns := sql_columns||','||c_r.column_name;
                        sql_columnvalues:=sql_columnvalues||','||''''||to_char(SYSDATE,'yyyy-MM-dd HH:mm:ss');
                               END IF ;
                                        ELSIF c_r.data_type = 'NUMBER' THEN
                                           IF  tableType =1 THEN  -- update
                                                   IF sqlOrNet = 1 THEN   --1 sql  0 net
                                                      sql_columns :=sql_columns||','||c_r.column_name||'='||0;
                                                     ELSE
                                                            sql_columns :=sql_columns||','||c_r.column_name||'=:'||c_r.column_name;
                                                   END IF;
                                          ELSE
                                             sql_columns := sql_columns||','||c_r.column_name;
                                           sql_columnvalues:=sql_columnvalues||','||0;
                                             END IF ;
                                        ELSE
                                             IF  tableType =1 THEN  -- update
                                                   IF sqlOrNet = 1 THEN   --1 sql  0 net
                                                  sql_columns :=sql_columns||','||c_r.column_name||'='||'''''';
                                                     ELSE
                                                            sql_columns :=sql_columns||','||c_r.column_name||'=:'||c_r.column_name;
                                                   END IF;
                                           ELSE
                                                    sql_columns := sql_columns||','||c_r.column_name;
                                                  sql_columnvalues:=sql_columnvalues||','||'''''';
                                            END IF ;
                                        END IF ;
                                END ;
                            ELSE
                                     BEGIN
                                        IF c_r.data_type = 'DATE' THEN
                                            IF  tableType =1 THEN  -- update
                                                   IF sqlOrNet = 1 THEN   --1 sql  0 net
                                                      sql_columns :=c_r.column_name||'='||''''||to_char(SYSDATE,'yyyy-MM-dd HH:mm:ss')||'''';
                                                     ELSE
                                                            sql_columns :=c_r.column_name||'=:'||c_r.column_name;
                                                   END IF;
                                           ELSE
                                             sql_columns := sql_columns||c_r.column_name;
                                           sql_columnvalues:=sql_columnvalues||''''||to_char(SYSDATE,'yyyy-MM-dd HH:mm:ss')||'''';
                                             END IF;
                                        ELSIF c_r.data_type = 'NUMBER' THEN
                                              IF  tableType =1 THEN  -- update
                                                         IF sqlOrNet = 1 THEN   --1 sql  0 net
                                                                    sql_columns :=c_r.column_name||'='||0;
                                                         ELSE
                                                                 sql_columns :=c_r.column_name||'=:'||c_r.column_name;
                                                         END IF;
                                                 ELSE
                                                 sql_columns := sql_columns||c_r.column_name;
                                                 sql_columnvalues:=sql_columnvalues||0;
                                                 END IF;
                                        ELSE
                                              IF  tableType =1 THEN  -- update
                                                         IF sqlOrNet = 1 THEN   --1 sql  0 net
                                                                    sql_columns :=c_r.column_name||'='||'''''';
                                                         ELSE
                                                                    sql_columns :=c_r.column_name||'=:'||c_r.column_name;
                                                         END IF;
                                                 ELSE
                                                     sql_columns := sql_columns||c_r.column_name;
                                                     sql_columnvalues:=sql_columnvalues||'''''';
                                                 END IF;
                                        
                                        END IF ;
                                     END;
                          END IF ;
                            
           END LOOP;
           --关闭游标
           CLOSE  c_t;
                     END;
      END;
            --0 =insert 1 =update 2=delete 3=select  
            --生成对于的sql
            IF tableType=0 THEN
      tableOutStr:='insert into '||tableName||' ('||sql_columns||') values('||sql_columnvalues||')';
            ELSIF tableType=1 THEN
            tableOutStr:='update  '||tableName||' set  '||sql_columns;
            ELSE
            tableOutStr:='select   '||sql_columns||' from   '||tableName;
            END IF ;
  END;

Oracle存储1.1的更多相关文章

  1. oracle存储参数(storage子句)含义及设置技巧

    可用于:表空间.回滚段.表.索引.分区.快照.快照日志 参数名称 缺省值 最小值 最大值 说明 INITIAL 5(数据块) 2(数据块) 操作系统限定 分配给Segment的第一个Extent的大小 ...

  2. oracle存储大文本clob、blob

    oracle存储大文本clob.blob 1 package cn.itcast.web.oracle.util; 2 3 import java.sql.Connection; 4 import j ...

  3. php调用oracle存储

    //todo 调用oracle 存储$config = //数据库配置文件 里面包含 用户密码和host和端口以及dbname $conn = oci_connect($config['usernam ...

  4. Oracle存储——逻辑结构

    Oracle 数存储——物理结构 Oracle存储结构:物理结构+逻辑结构 Oracle 数据库存储逻辑结构 Oracle Schema Objects(Schema Object Storage A ...

  5. Oracle存储函数,存储过程

    一.Oracle存储函数:存储的PL/SQL语法块,完成特定的功能.1.语法: 函数关键字: function (1)创建函数 CREATE [OR REPLACE] FUNCTION <fun ...

  6. oracle存储海量数据 设计方案

    日历基本活动表的数据有四千万条,在这些生产库业务中是小的了. 从三个方面提高效率: 1.sql语句 要绑定变量,sql语句书写规范这些,包括的就多了.主要目的就是提高数据库吞吐量及业务SQL响应时间. ...

  7. ibatis.net调用oracle存储过返回游标SYS_REFCURSOR结果集

    最近在用ibatis.net框架和oracle 11g开发一套程序.其中有一个需求就是通过存储过程,查询指定条件的数据集. 但是在开发的过程中遇到了问题,问题如下: 1.如何通过ibatis.net执 ...

  8. Java调用Oracle存储Package

    Oracle的包Package中可以有很多存储,可通过该包的总调入口在java中直接调用. //java调用oracle的package代码 public boolean cal() throws j ...

  9. ORACLE 存储函数

    前奏: 必要的概念: ORACLE 提供能够把 PL/SQL 程序存储在数据库中.并能够在不论什么地方来运行它.这样就叫存储过 程或函数. 过程和函数统称为 PL/SQL 子程序.他们是被命名的 PL ...

  10. Oracle 存储结构三

    Oracle数据库服务器自动管理空间的方法 段空间的分配 空间以区间的形式分配给段,区间是一组连续的Oracle块.每个数据文件都有一个位图,来描述文件中块的状态,块可能是空闲的,也可能是区间中已分配 ...

随机推荐

  1. vue-cli 目录结构详细讲解

    https://juejin.im/post/5c3599386fb9a049db7351a8 vue-cli 目录结构详细讲解 目录 结构预览 ├─build // 保存一些webpack的初始化配 ...

  2. 表单单选按钮input[type="radio"]

    <!DOCTYPE html> <html lang="zh"> <head> <title></title> < ...

  3. varStatus实现<c:forEach获取元素的下标 集合长度

    有时候需要获取元素的下标,来实现一个编号的效果 那么使用 varStatus可以实现 代码 效果 如果需要把序号倒着数 那就用集合的长度减去当前下标 首先引入 <%@ taglib prefix ...

  4. HDU--2639 Bone Collector II(01背包)

    题目http://acm.hdu.edu.cn/showproblem.php?pid=2639 分析:这是求第K大的01背包问题,很经典.dp[j][k]为背包里面装j容量时候的第K大的价值. 从普 ...

  5. 理解JWT

    1. JSON Web Token是什么 JSON Web Token (JWT)是一个开放标准(RFC 7519),它定义了一种紧凑的.自包含的方式,用于作为JSON对象在各方之间安全地传输信息.该 ...

  6. python 运行python -m pip list 出现错误

    1.出现如下错误提示 2解决方案 解决方法:(windows)在C:\Users{用户名}\ 目录下创建名称为pip的文件夹,里面创建文本文件,内容为 [list] format=columns 保存 ...

  7. JavaScript RegExp 对象的三种方法

    JavaScript RegExp 对象有 3 个方法:test().exec() 和 compile().(1) test() 方法用来检测一个字符串是否匹配某个正则表达式,如果匹配成功,返回 tr ...

  8. leetcode算法题笔记|two sum

    题目: 我的答案: /** * @param {number[]} nums * @param {number} target * @return {number[]} */ var twoSum = ...

  9. oauth2使用心得-----基本概念以及认证服务器搭建

    应用场景 我们假设你有一个“云笔记”产品,并提供了“云笔记服务”和“云相册服务”,此时用户需要在不同的设备(PC.Android.iPhone.TV.Watch)上去访问这些“资源”(笔记,图片) 那 ...

  10. Leetcode129. Sum Root to Leaf Numbers求根到叶子节点数字之和

    给定一个二叉树,它的每个结点都存放一个 0-9 的数字,每条从根到叶子节点的路径都代表一个数字. 例如,从根到叶子节点路径 1->2->3 代表数字 123. 计算从根到叶子节点生成的所有 ...