Oracle 踩坑记

Oracle 踩坑记
1、Oracle 用连接工具(Navicat、SQL Developer)创建的用户名的字母要大写,否则无法连接,报ERROR ora-01017:inva…

	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、  

 

 

 

 

 

 

 

【附录】:

一 序列定义

 

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

 

Oracle 踩坑记

原文地址:https://www.cnblogs.com/myzan/p/13689878.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/6682.html

(0)
上一篇 2023-04-05 18:30
下一篇 2023-04-05

相关推荐

  • SQLyog12.08详细安装教程[通俗易懂]

    SQLyog12.08详细安装教程[通俗易懂]SQLyog安装教程 一、软件下载 为了更好的学习,我们需要可视化界面,而不仅仅是通过命令行黑窗口管理数据库。SQLyog 就是一个快速而简洁的图形化管理MYSQL数据库的工具。 SQLyog12.0

    2023-02-01
    140
  • 如何以本地图片生成链接

    如何以本地图片生成链接在网站开发过程中,经常需要使用图片,而有时候需要将图片转换为链接以便于跳转到其他页面。如果图片已经存储在本地,该如何生成链接呢?本文将为大家介绍如何以本地图片生成链接。

    2024-05-08
    77
  • 封装jdbc工具类增删改查_jdbc工具类

    封装jdbc工具类增删改查_jdbc工具类
    封装JDBC工具类 在实际JDBC的使用中,存在着大量的重复代码:例如连接数据库、关闭数据库等这些操作! 我们需要把传统的JDBC代码进行重构,抽取出通用的…

    2023-04-05
    168
  • 数据库三种完整性约束_数据库定义外键约束的语句

    数据库三种完整性约束_数据库定义外键约束的语句 1.创建表 –创建学生班级表 create table StuClass ( ClassId int primary key, –班级ID 主键约束 ClassName nvarchar…

    2023-03-24
    172
  • 用Python画一个五角星

    用Python画一个五角星随着科技的发展,人们有越来越多的机会接触到计算机编程。而Python语言作为一种易于学习且功能强大的语言,受到越来越多的人的欢迎。Python可以用于各种不同的领域,从数据科学到机器学习,从网站开发到游戏制作。本文将介绍如何使用Python画一个五角星,不仅能够提高Python编程技能,还能够突出画图能力。

    2024-06-08
    46
  • PXC高可用数据库安装部署

    PXC高可用数据库安装部署说明 Percona XtraDB Cluster(简称PXC),是由percona公司推出的mysql集群解决方案。特点是每个节点都能进行读写,且都保存全量的数据。也就是说在任何一个节点进行写入操…

    2023-04-08
    163
  • centos7下MySQL5.7修改默存储路径[通俗易懂]

    centos7下MySQL5.7修改默存储路径[通俗易懂]安装MySQL中YUM默认安装路径是/var/lib/mysql下,有时候该目录分配的磁盘空间并不大,需要迁移到新的磁盘目录 df -h 查看磁盘空间大小 本次迁移到 /home目录下 1.在home

    2022-12-26
    149
  • MySQL学习(一)「建议收藏」

    MySQL学习(一)「建议收藏」引言 MySQL 是最流行的关系型数据库管理系统,在 WEB 应用方面 MySQL 是最好的 RDBMS(Relational Database Management System:关系数据库管理系…

    2023-03-21
    163

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注