Oracle一些使用的细节
2018-02-27 10:51
211 查看
P_变量名 代表参数
V_变量名 代表变量
尽量用 表A.属性%type
恢复10分钟之前的数据
1.执行 select * from A as of timestamp sysdate-10/1440;
该SQL语会查找出距离现在10分钟之前A表的所有数据。
sysdate-10/1440表示距离现在10分钟之前,1440这个数字表示一天有1440分钟。
2.查到数据后,插入中间表 tab_temp
Insert into tab_temp select * from A as of timestamp sysdate-10/1440;
3。再将表A改名或删除,接着将中间表tab_temp 改名为 A
alert table A rename to A_bak;
alert table tab_temp rename to A;
cmd导入Oracle数据
IMP Oracle用户名/密码 File=‘dmp路径’ full=y
DUP_VAL_ON_INDEX:判断唯一索引上有重复值
-------------------------------------------------------------------------------------------------------------------------------------------
首先创建序列:create sequence seq;
语法:
CREATE SEQUENCE 序列名
[INCREMENT BY n] --每次加几
[START WITH n] --序列从几开始
[{MAXVALUE/ MINVALUE n|NOMAXVALUE}] --小值、大值限制
比CREATE SEQUENCE seq start with 1 increment by 1; --建立了额从1开始每次加1序列
访问序列时用 序列名称.nextval语法
这就创建好了,然后 seq.nextval 就会返回一个值,不会重复的值,
insert into tablename values(seq.nextval,'test');
insert into tablename values(seq.nextval,'test');
insert into tablename values(seq.nextval,'test');
这样前3个id 分别是 1,2,3
-------------------------------------------------------------------------------------------------------------------------------------------
OTHERS处理器应该是异常处理块中的最后的异常处理器,因为它是用来捕获除了别的异常处理器处理以外的所有的Oracle异常,所以在程序的最外层使用一个OTHERS处理器的话,将可以确保所有的错误都会被检测到。
在一个内在的异常中,SQLCODE返回Oracle错误的序号,而SQLERRM返回的是相应的错误消息,错误消息首先显示的是错误代码。SQLCODE返回的是负数,除非Oracle的错误为“ORA-01403:NO DATA FOUND”(译:ORA-01403:未找到数据),当Oracle错误为“ORA-01403:NO DATA FOUND”时,其对应的SQLCODE为+100。对于用户自定义的异常,SQLCODE返回的是+1,而SQLERRM返回的是User-Defined Exception。
一个Oracle的错误消息最多只能包含512个字节的错误代码。
sqlerrm:SQLERRM是一则函数。oracle sqlerrm函数 sqlerrm函数返回指定错误代码的错误信息。
sqlcode:数据库操作的返回码,其中0--成功;-1--失败;100--没有检索到数据。
用法:
sqlerrm和sqlcode用法要注意的是不能直接在存储过程使用,他需要有一个变量来接受它,也就是它要赋值形式去实现;
V_变量名 代表变量
尽量用 表A.属性%type
恢复10分钟之前的数据
1.执行 select * from A as of timestamp sysdate-10/1440;
该SQL语会查找出距离现在10分钟之前A表的所有数据。
sysdate-10/1440表示距离现在10分钟之前,1440这个数字表示一天有1440分钟。
2.查到数据后,插入中间表 tab_temp
Insert into tab_temp select * from A as of timestamp sysdate-10/1440;
3。再将表A改名或删除,接着将中间表tab_temp 改名为 A
alert table A rename to A_bak;
alert table tab_temp rename to A;
cmd导入Oracle数据
IMP Oracle用户名/密码 File=‘dmp路径’ full=y
DUP_VAL_ON_INDEX:判断唯一索引上有重复值
-------------------------------------------------------------------------------------------------------------------------------------------
首先创建序列:create sequence seq;
语法:
CREATE SEQUENCE 序列名
[INCREMENT BY n] --每次加几
[START WITH n] --序列从几开始
[{MAXVALUE/ MINVALUE n|NOMAXVALUE}] --小值、大值限制
比CREATE SEQUENCE seq start with 1 increment by 1; --建立了额从1开始每次加1序列
访问序列时用 序列名称.nextval语法
这就创建好了,然后 seq.nextval 就会返回一个值,不会重复的值,
insert into tablename values(seq.nextval,'test');
insert into tablename values(seq.nextval,'test');
insert into tablename values(seq.nextval,'test');
这样前3个id 分别是 1,2,3
-------------------------------------------------------------------------------------------------------------------------------------------
OTHERS处理器应该是异常处理块中的最后的异常处理器,因为它是用来捕获除了别的异常处理器处理以外的所有的Oracle异常,所以在程序的最外层使用一个OTHERS处理器的话,将可以确保所有的错误都会被检测到。
在一个内在的异常中,SQLCODE返回Oracle错误的序号,而SQLERRM返回的是相应的错误消息,错误消息首先显示的是错误代码。SQLCODE返回的是负数,除非Oracle的错误为“ORA-01403:NO DATA FOUND”(译:ORA-01403:未找到数据),当Oracle错误为“ORA-01403:NO DATA FOUND”时,其对应的SQLCODE为+100。对于用户自定义的异常,SQLCODE返回的是+1,而SQLERRM返回的是User-Defined Exception。
一个Oracle的错误消息最多只能包含512个字节的错误代码。
sqlerrm:SQLERRM是一则函数。oracle sqlerrm函数 sqlerrm函数返回指定错误代码的错误信息。
sqlcode:数据库操作的返回码,其中0--成功;-1--失败;100--没有检索到数据。
用法:
sqlerrm和sqlcode用法要注意的是不能直接在存储过程使用,他需要有一个变量来接受它,也就是它要赋值形式去实现;
相关文章推荐
- oracle的一些使用细节
- Oracle SQLPlus 一些使用经验记录(设置环境变量和字符串比较)
- MS Server和Oracle中对NULL处理的一些细节差异
- MS Server和Oracle中对NULL处理的一些细节差异
- Oracle中日期的一些简单使用
- MS Server和Oracle中对NULL处理的一些细节差异
- Oracle学习中的一些细节
- 使用oracle的一些技巧方法
- Java transient关键字使用小结及一些需要注意的细节
- C语言中 sizeof 操作符使用时的一些细节 和 指针类型的大小
- 使用oracle时一些优化事项(转自:http://www.ij2ee.com/2010/07/22/some-optimization-issues-when-using-the-oracle.html)
- [记录]在Linux中Oracle安装成功后,首次启动使用时,会出现的一些问题总结和解决办法
- 最近oracle使用过程中的一些总结
- Oracle 日期的一些简单使用
- 关于oracle中LONG数据类型使用上的一些总结
- Oracle中的一些相关指令的使用
- 两天的oracle学习经验,以及对数据库脚本的认识。sql语句的一些细节还是费了不少劲的。
- 一些oracle的使用技巧
- 使用CMake构建Ogre工程文件时的一些小细节
- Path.Combine (合并两个路径字符串)方法的一些使用细节