Oracle 踩坑记
1、Oracle 用连接工具(Navicat、SQL Developer)创建的用户名的字母要大写,否则无法连接,报ERROR ora-01017:invalid username/password
2、Oracle 主键自增设置过程中,创建完序列后,创建触发器成功,但是报错:编译错误 ,如何解决?将表里面的字段的字母,都改成大写字母即可。
[序列]
1 CREATE SEQUENCE SEQNAME //序列名字 2 INCREMENT BY 1 //每次自增1, 也可写非0的任何整数,表示自增,或自减 3 START WITH 1 //以该值开始自增或自减 4 MAXVALUE 1.0E20 //最大值;设置NOMAXVALUE表示无最大值 5 MINVALUE 1 //最小值;设置NOMINVALUE表示无最大值 6 CYCLE or NOCYCLE //设置到最大值后是否循环; 7 CACHE 20 //指定可以缓存 20 个值在内存里;如果设置不缓存序列,则写NOCACHE 8 ORDER or NOORDER //设置是否按照请求的顺序产生序列
【触发器】
create or replace trigger trg_userid_inc // trg_userid_inc 是序列的名称
before insert on users //users 表的名称
for each row
begin
select table_sequence.nextval into:new.id from dual; end;
3、SpringBoot连接Oracle数据库服务器时,请注意服务器的防火墙,要开放对应的端口(默认:1521)。否则报错:The Network Adapter could not establish the connection
4、SpringBoot 安装Oracle依赖,需要maven从本地加载Ojdbc8.jar,例如ojdbc8.jar(version:12.2.0.1)放在本地的D盘目录下,则maven安装命令如下。
mvn install:install-file -Dfile=D:\ojbdc8.jar -Dversion=12.2.0.1 -DgroupId=com.oracle -DartifactId=ojdbc8 -Dpackagin=jar
Pom.xml 的依赖引用
<dependency>
<groupId>com.oracle</groupId>
<artifactId>ojdbc8</artifactId>
<version>12.2.0.1</version>
</dependency>
5、Navicat 连接Oracle,创建表,查询表,报错:ORA-00942:表或视图不存在。原因是Navicat的select语句不加双引号,会默认把Users转换成USERS,而Oracle是区分大小写字母的,所以没有查到USERS这个表,如果要查询Users这个表需要加双引号。
得出如下结论:
a、oracle表和字段是有大小写的区别。oracle默认是大写,如果我们用双引号括起来的就区分大小写,如果没有,系统会自动转成大写。
b、我们在使用navicat使用可视化创建数据库时候,navicat自动给我们加上了双引号“”。
因此建议:
a.建议我们的可视化操作者还是养成手写sql语句的习惯,我们在创建的时候就不要使用了双引号!
b、比较笨的方法是数据表名字大写,这样也可以避免此问题
【附录】:
一 序列定义
序列(SEQUENCE)是序列号生成器,可以为表中的行自动生成序列号,产生一组等间隔的数值(类型为数字)。不占用磁盘空间,占用内存。
其主要用途是生成表的主键值,可以在插入语句中引用,也可以通过查询检查当前值,或使序列增至下一个值。
二 创建序列
创建序列需要CREATE SEQUENCE系统权限。序列的创建语法如下:
CREATE SEQUENCE 序列名
[INCREMENT BY n]
[START WITH n]
[{MAXVALUE/ MINVALUE n| NOMAXVALUE}]
[{CYCLE|NOCYCLE}]
[{CACHE n| NOCACHE}];
其中:
1) INCREMENT BY用于定义序列的步长,如果省略,则默认为1,如果出现负值,则代表Oracle序列的值是按照此步长递减的。
2) START WITH 定义序列的初始值(即产生的第一个值),默认为1。
3) MAXVALUE 定义序列生成器能产生的最大值。选项NOMAXVALUE是默认选项,代表没有最大值定义,这时对于递增Oracle序列,系统能够产生的最大值是10的27次方;对于递减序列,最大值是-1。
4) MINVALUE定义序列生成器能产生的最小值。选项NOMAXVALUE是默认选项,代表没有最小值定义,这时对于递减序列,系统能够产生的最小值是?10的26次方;对于递增序列,最小值是1。
5) CYCLE和NOCYCLE 表示当序列生成器的值达到限制值后是否循环。CYCLE代表循环,NOCYCLE代表不循环。如果循环,则当递增序列达到最大值时,循环到最小值;对于递减序列达到最小值时,循环到最大值。如果不循环,达到限制值后,继续产生新值就会发生错误。
6) CACHE(缓冲)定义存放序列的内存块的大小,默认为20。NOCACHE表示不对序列进行内存缓冲。对序列进行内存缓冲,可以改善序列的性能。
大量语句发生请求,申请序列时,为了避免序列在运用层实现序列而引起的性能瓶颈。Oracle序列允许将序列提前生成 cache x个先存入内存,在发生大量申请序列语句时,可直接到运行最快的内存中去得到序列。但cache个数也不能设置太大,因为在数据库重启时,会清空内存信息,预存在内存中的序列会丢失,当数据库再次启动后,序列从上次内存中最大的序列号+1 开始存入cache x个。这种情况也能会在数据库关闭时也会导致序号不连续。
7) NEXTVAL 返回序列中下一个有效的值,任何用户都可以引用。
8) CURRVAL 中存放序列的当前值,NEXTVAL 应在 CURRVAL 之前指定 ,二者应同时有效。