Oracle 脚本记录
2024-08-27 02:33:09
给表创建序列或触发器
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 <
最新文章
- iOS多线程开发资源抢夺和线程间的通讯问题
- Esfog_UnityShader教程_镜面反射SpecularReflection
- Android 隐藏RadoiButton左边按钮
- 【iOS开发之OC和JS互调】
- 逃出克隆岛 (codevs 2059)
- [bzoj4922]Karp-de-Chant Number
- linux系统安装redis
- 使用 pjsip 代码独立开发
- 阿里云ECS配置iptables
- ajax异步请求该嵌套还是并列?
- Redis hash数据结构
- Connection:Keep-alive
- STL Set和multiset 容器
- java性能分析工具 jconsole.exe
- Tensorflow BatchNormalization详解:3_使用tf.layers高级函数来构建带有BatchNormalization的神经网络
- Unity四元数和旋转
- vue中$nextTick的用法
- JSP应用开发 -------- 电纸书(未完待续)
- Scala学习——类,继承,接口(中)
- python学习--学习时间属性的应用(time / datetime )