开发者社区> 橘子红了呐> 正文

Oracle 存储过程动态建表

简介:
+关注继续查看

动态sql,顾名思义就是动态执行的sql,也就是说在没执行之前是动态的拼接的。

任务

传入参数:新建的表名hd+当前的年和月,例如hd_201105
表结构是:字段1:id ,类型是number,可以自动增加
字段2:name 类型是varcha2,长度20
字段3:city 类型是varchar2,长度20

 

建立序列:

复制代码
create sequence t_id
increment by 1
start with 1
nomaxvalue
cache 20;
复制代码

 

建立自动建表过程:

复制代码
create or replace procedure pro_createtable(tname in varchar2  default to_char(sysdate,'yyyymm'))
as
  v_sql varchar2(200);
  v_tname varchar2(10);
begin
  if length(tname)<>6 then
    raise_application_error(-20000,'输入参数长度不够,不能转换为日期格式!');
  end if ;
  if to_number(substr(tname,5,2)) not between 1 and 12 then
     raise_application_error(-20001,'输入参数中不包含有效的月份数字,不能转换为日期格式!');
  end if ;
  --v_tname:=to_char(to_date(tname,'yyyymm'),'yyyymm');
  v_tname:='hd_'||tname;
  v_sql:='create table '||v_tname||' ('||
         'id number not null,'||
         'name varchar2(20),'||
         'city varchar2(20))'||
         'tablespace users';
  execute immediate v_sql;
end;
复制代码

 

 测试:

复制代码
begin
    pro_createtable;
    pro_createtable('201106');
    pro_createtable('201115');--报错
end;
复制代码

 

 

 

 

 

参考文章

想用oracle的存储过程动态建表

oracle存储过程中如何使用动态sql

 

没有整理与归纳的知识,一文不值!高度概括与梳理的知识,才是自己真正的知识与技能。 永远不要让自己的自由、好奇、充满创造力的想法被现实的框架所束缚,让创造力自由成长吧! 多花时间,关心他(她)人,正如别人所关心你的。理想的腾飞与实现,没有别人的支持与帮助,是万万不能的。






    本文转自wenglabs博客园博客,原文链接:http://www.cnblogs.com/arxive/p/5968567.html,如需转载请自行联系原作者



版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
oracle查看系统存储过程
select line,text from dba_source where name='PRO_E_F_ORDER_STAT'; select object_name,object_typ...
460 0
Oracle rac 基于 NFS存储的实现
使用nfs搭建rac在Oracle应用方案中也比较成熟,在要求性能不太高的情况下可以选择使用
5349 0
[20150414]oracle日期存储.txt
[20150414]oracle日期存储.txt --以前自己没有注意的问题,自己学习看看. SCOTT@test> @ver1 PORT_STRING                    VERSION        BANNER ------...
737 0
C/C++封装库ocicpplib调用Oracle存储过程的方法
工作这么多年,一直使用Mysql, Oracle数据库没有接触过, 这次要使用C/C++语言来调用Oracle的存储过程, 懒得自己去看OCI的API了, 直接上网找别人封装的库, 最后发现了这个ocicpplib, 下载了看了一下, 还不错, 使用起来比较简单。
1178 0
【原】Oracle VirtualBox搭建RAC共享存储划分
作者:david_zhang@sh 【转载时请以超链接形式标明文章】 链接:http://www.cnblogs.com/david-zhang-index/archive/2012/07/12/2587826.
984 0
Oracle 11g R2 RAC with ASM存储迁移--Rman copy&ASM REBALANCE
by acdante Oracle 11g R2 RAC with ASM存储迁移                                            -----Rman copy&ASM REBALANCE     环境介绍 VMware版本:VMware12pro 主机操作系统:RHEL6.5_64 共享存储使用VMWARE创建共享磁盘文件 数据库版本:Oracle11gR2 11.2.0.4.0_RAC   Oracle数据库文件部署在ASM磁盘组上,需要在不停机或者尽量短的停机时间完成存储迁移。
2663 0
3402
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
JS零基础入门教程(上册)
立即下载
性能优化方法论
立即下载
手把手学习日志服务SLS,云启实验室实战指南
立即下载