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 之前指定 ,二者应同时有效。

 

posted on 2020-09-18 10:40  暮云寨  阅读(238)  评论(0编辑  收藏  举报

导航