给表创建序列或触发器

create or replace procedure p_createseq(tablename in varchar2,key in varchar2)
Authid Current_User --使用角色权限,否则无法创建序列或表
is
strsql varchar2(500);
t_key varchar2(500);
begin
--创建序列
strsql:='create sequence seq_'||tablename||
' minvalue 1 maxvalue 99999999 start with 1 increment by 1 nocache';
execute immediate strsql;
--设置触发器默认主键名
if(key is NULL) then t_key := 'ID' ;
else t_key := key;
end if;
--创建触发器
strsql := 'CREATE OR REPLACE TRIGGER TRG_'||tablename||'
BEFORE INSERT ON '||tablename ||'
FOR EACH ROW
BEGIN
SELECT SEQ_'||tablename||'.NEXTVAL INTO :NEW.'||t_key||' FROM DUAL;
END; ';
execute immediate strsql;
end p_createseq;

  Authid Current_User 指明使用当前角色权限,否则无法创建表或者序列。默认存储过程无法使用当前角色权限。

  调用存储过程,传递表名和主键名就好

创建表空间、用户、授权等

conn / as sysdba;
create tablespace jinwin;
create user jwst identified by jwst default tablespace jinwin temporary tablespace temp;
grant dba to jwst;
conn jwst/jwst;

按字段分组,并取前N条

select * from ( select row_number() over (partition by sqbm  order by  SERIALNO_  ) RN from table) t where rn < 

最新文章

  1. iOS多线程开发资源抢夺和线程间的通讯问题
  2. Esfog_UnityShader教程_镜面反射SpecularReflection
  3. Android 隐藏RadoiButton左边按钮
  4. 【iOS开发之OC和JS互调】
  5. 逃出克隆岛 (codevs 2059)
  6. [bzoj4922]Karp-de-Chant Number
  7. linux系统安装redis
  8. 使用 pjsip 代码独立开发
  9. 阿里云ECS配置iptables
  10. ajax异步请求该嵌套还是并列?
  11. Redis hash数据结构
  12. Connection:Keep-alive
  13. STL Set和multiset 容器
  14. java性能分析工具 jconsole.exe
  15. Tensorflow BatchNormalization详解:3_使用tf.layers高级函数来构建带有BatchNormalization的神经网络
  16. Unity四元数和旋转
  17. vue中$nextTick的用法
  18. JSP应用开发 -------- 电纸书(未完待续)
  19. Scala学习——类,继承,接口(中)
  20. python学习--学习时间属性的应用(time / datetime )

热门文章

  1. C++学习011-常用内存分配及释放函数
  2. Java并发基础--线程通信
  3. LeetCode - 66. Plus One(0ms)
  4. asp.net页面中的Console.WriteLine结果如何查看
  5. Android Studio 添加模块依赖
  6. 浅谈c语言和c++中struct的区别
  7. epc笔记
  8. java线程(2)——模拟生产者与消费者
  9. 【Autofac】- 创建的类的生命周期
  10. Windows IRP