`

oracle中实现自动增长列

阅读更多
oracle中实现自动增长列不能够像 SqlServer中在 表中直接加标示,而是要借助序列来实现。下面简单介绍一下,oracle中实现自动增长列的一个方法

步骤:
1  创建一个序列来实现自动增长。
   
     create sequence user_sequence1
         start with  1   ----初值
           increment by 1     --增量
            nomaxvalue       --没有最大值
            nocycle       --不能循环
            nocache        --不缓存

        注意:序列创建完成时不能加 ;结束

2  创建一个表

      create table student(
         id numbert,
         name varchar2(10)
      )

3   测试

        insert into student values (user_sequence1.nextval,'aaa');
       select * from student;


这样能够实现自动增长列的添加,但是 我们现在一般都是 数据库和程序分离 所以我们最好能够在数据库中把自动增长写好 而程序中只需要加值不需要知道 你是创建的那个序列。

步骤:
1           和上面的第一个一样  省略

2              和上面的一样    省略

3        创建一个触发器

         create or replace trigger user_trigger1
         before insert on student
         for each row
          declare
           tempnum number;
            begin
              select user_sequence1.nextval into tempnum from dual;
               :new.id  :=tempnum;
              end;

4 测试
              insert  into student values (5,'aaa');
              select * from student;


说明:这里还是需要给一个number类型的值,但是无论给什么值它都是按照序列的值填充的。所有我们可以在设计数据库的时候给数据库默认值 然后我们添加的时候直接给 default即可。
1
0
分享到:
评论

相关推荐

    Oracle与Mysql自动增长列(id)的区别

    这里所说的自动增长列,主要是指一个表中主键id的自动增长。 Oracle与Mysql不同,不能在CREATE建立表时设置自动增长列功能。 Oracle必须通过创建sequence序列来实现自动增加列的功能。 首先要建立序列(当然必须要先...

    Oracle数据库管理员技术指南

    6.10 用 Oracle 复制实现失败切换 6.10.1 基本复制 6.10.2 基本复制失败切换的优点 6.10.3 基本复制失败切换的缺点 6.11 将高级复制用于失败切换 6.11.1 高级复制失败切换的优点 6.11.2 高级复制失败切换的...

    最全的oracle常用命令大全.txt

    下面按类别列出一些ORACLE用户常用数据字典的查询使用方法。 1、用户 查看当前用户的缺省表空间 SQL>select username,default_tablespace from user_users; 查看当前用户的角色 SQL>select * from user_...

    Oracle触发器

    –今天我们根据学到的东西实现一个id列自动增长的触发器 –首先我们需要建个表,主键id,name不为空 create table student( id number primary key, name varchar2(50) not null ) –查一下看看 select * from ...

    Oracle9i的init.ora参数中文说明

    值范围: Oracle8i National Language Support Guide 中指定的任何有效的10 字节字符串。 默认值: 从 NLS_TERRITORY 中获得 nls_date_language: 说明: 指定拼写日期名, 月名和日期缩写词 (AM, PM, AD, BC) 的语言。...

    【总结】数据库自增字段的 3 种实现方式

    在设计数据库的表结构时,经常会使用一个自动增长的数字序列作为主键字段(代理主键)。除了作为主键使用之外,自增字段也可以用于记录各个操作发生的先后顺序,因为它具有递增特性。当我们插入一行数据时,数据库会...

    dotnetcoding ORM 代码生成器

    数据库中的所有逻辑对象表,列,字段,主键,外键,Null, Default,唯一索引都在类里得到了体现,同时还支持代码表,代码列,自增长机制. 系统支持完整的数据操作功能,支持带事务功能的数据操作,提供数据自动装载功能,有很强...

    delete from 表名与truncate table 表名区别

    但是truncate能使自动增长的列的值返回为默认的种子 2.truncate只能一次清空,不能按条件删除。但是delete可以按条件清除部分记录。 3.truncate清空数据表性能(速度)比delete快。 4.truncate不会记录到系统日志,...

    Java面试宝典2020修订版V1.0.1.doc

    37、oracle如何设置主键自动增长? 53 38、表连接、子查询的区别是什么?它们可以相互转化吗?你倾向于用哪种,为什么? 54 39、oracle数据库表的备份及还原 54 40、谈谈你知道的数据库和中间件 54 41、oracle和...

    jdbc基础和参考

    1.increment:自动增长 select max(id) from table; 找到最大值之后+1赋给要持久化的对象 2.assigned:指派 hibernate不在自动生成主键值,需要你在插入时自己指明 3.hilo:高低值算法,由数据库表提供高值,程序...

    Hibernate注解

    * GenerationType.IDENTITY 主键由数据库自动生成(主要是自动增长类型) * GenerationType.SEQUENCE 根据底层数据库的序列来生成主键,条件是数据库支持序列。(这个值要与generator一起使用) * generator 指定...

    浅谈大数据及大数据分析.doc

    直到最近,大多数分析师还无法对此呼叫日志历史记录 RDBMS 中最常见和高度结构化的数据进行分析,因为文本信息的挖掘需要耗费大量劳力,而且 难以实现自动运行。 3 大数据四种主要的数据结构类型 人们最熟悉的往往是...

    经典SQL语句大全

    22、说明:列示type、vender、pcs字段,以type字段排列,case可以方便地实现多重选择,类似select 中的case。 select type,sum(case vender when 'A' then pcs else 0 end),sum(case vender when 'C' then pcs else ...

    数据库操作语句大全(sql)

    22、说明:列示type、vender、pcs字段,以type字段排列,case可以方便地实现多重选择,类似select 中的case。 select type,sum(case vender when 'A' then pcs else 0 end),sum(case vender when 'C' then pcs else ...

    sql经典语句一部分

    22、说明:列示type、vender、pcs字段,以type字段排列,case可以方便地实现多重选择,类似select 中的case。 select type,sum(case vender when 'A' then pcs else 0 end),sum(case vender when 'C' then pcs else ...

    (重要)AIX command 使用总结.txt

    H ->显示列输出前面的头部分,即输出中包括列头部分 P ->列出预定义设备对象类中设备的有关信息,即支持的设备,缺省显示信息包括class,type,subclass,description r ColumnName ->指定列名 S State ->列出指定状态...

    PHP基础教程 是一个比较有价值的PHP新手教程!

    PHP的应用在个人性质的web工程中增长显著。根据Netcraft在1999年10月的报告,有931122个域和321128个IP地址利用PHP技术。 1.2 PHP的先进之处 应用PHP有许多好处。当然已知的不利之处在于PHP由于是开放源码项目,...

Global site tag (gtag.js) - Google Analytics