我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Oracle 踩坑记

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码


	Oracle 踩坑记


	Oracle 踩坑记
[数据库教程]

Oracle 用连接工具(Navicat、SQL Developer)创建的用户名的字母要大写,否则无法连接,报ERROR  ora-01017:invalid username/password

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;     

     

SpringBoot连接Oracle数据库服务器时,请注意服务器的防火墙,要开放对应的端口(默认:1521)。否则报错:The Network Adapter could not establish the connection

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 的依赖引用    

    
    com.oracle
     ojdbc8
     12.2.0.1
    

  

 

 

 

 

 

 

 

【附录】:

一 序列定义

 

序列(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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Oracle 踩坑记

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Oracle 踩坑记

1、Oracle 用连接工具(Navicat、SQL Developer)创建的用户名的字母要大写,否则无法连接,报ERROR  ora-01017:invalid username/password2、Oracle 主键自增设置过程中,创建完序列后,创建触发

	Oracle 踩坑记
2022-03-25

Flask+Nginx踩坑记录

因为之前的网站项目使用的是Spring MVC,而且当时为了尽快赶完,代码结构非常粗暴,还存在大量的copy-paste代码,然后被师兄批评,然后决定接受师兄的建议,对网站进行重构,并且使用听说可以让我长寿一点的python【什么鬼。。。】
2023-01-31

使用Gorm操作Oracle数据库踩坑记录

目录下载依赖项目结构编辑go.mod将gorm降级定义model类型连接数据库 测试运行gorm是目前用得最多的go语言orm库,但是目前gorm官方并不支持oracle的驱动,需要用到第三驱动,最近有个项目要往oracle写数据,记录一下
2022-06-14

mybatisplus之Wrappers.ne踩坑记录解决

这篇文章主要为大家介绍了mybatisplus之Wrappers.ne踩坑记录解决,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-05-19

TypeScript中集成Tween.js踩坑记录

这篇文章主要介绍了TypeScript中集成Tween.js踩坑记录,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-01-28

编程热搜

目录