当前位置:  数据库>oracle

Oracle主键的设置

    来源: 互联网  发布时间:2017-03-23

    本文导语:   有两种方法可以设置Oracle主键,一种是自增长主键,另一种就是生成唯一序列。   一、自增长主键   --首先建一个表TEST   create table TEST   (   NID int PRIMARY KEY,   test1 varchar2(20),   test2 varchar2(20),   test3 varcha...

  有两种方法可以设置Oracle主键,一种是自增长主键,另一种就是生成唯一序列。

  一、自增长主键

  --首先建一个表TEST

  create table TEST

  (

  NID int PRIMARY KEY,

  test1 varchar2(20),

  test2 varchar2(20),

  test3 varchar2(20),

  test4 varchar2(20),

  test5 varchar2(20)

  )-- 再建一个序列SEQ_TEST

  create sequence SEQ_TEST

  minvalue 1        --最小值

  nomaxvalue        --不设置最大值

  start with 1      --从1开始计数

  increment by 1    --每次加1个

  nocycle           --一直累加,不循环

  nocache;          --不建缓冲区    以上代码完成了一个序列(sequence)的建立过程,名称为SEQ_TEST,范围是从1开始到无限大(无限大的程度是由你机器决定的),nocycle 是决定不循环,如果你设置了最大值那么你可以用cycle 会使seq到最大之后循环.对于nocache顺便说一下如果你给出了cache值那么系统将自动读取你的cache值大小个seq,这样在反复操作时会加快运行速度,但如果遭遇意外情况如当机了或oracle死了,则下次取出的seq值将和上次的不连贯.(如果连不连贯无所谓,建议用cache,因为时间就是金钱呀!)

  你只有了表和序列还不够,最好再建一个触发器来执行它!代码如下:

  CREATE OR REPLACE TRIGGER tg_test

  BEFORE INSERT ON test FOR EACH ROW WHEN (new.nid is null)

  begin

  select seq_test.nextval into:new.nid from dual;

  end;下面是测试

  select * from test

  insert into test(nid,test1) values(6,'aaa')

  insert into test(test1) values('bbb')


    
 
 

您可能感兴趣的文章:

  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • Oracle中serveroutput参数一次设置永久保存方法
  • window中oracle环境变量设置方法分享
  • 在jsp文件中怎么设置oracle的路径:很简单的,只是因为我不会;
  • Linux平台下Oracle9i数据库正确显示中文的设置
  • 急急急!!!Solaris中JSP运行环境(tomcat)应如何设置才能使jsp连接到ORACLE???
  • 驱动程序找不到Class.forName("oracle.jdbc.driver.OracleDriver");,在程序中还要设置什么?
  • 在Linux系统下远程连接oracle的防火墙设置
  • PB7 连接 Oracle 的设置方法
  • 将oracle用户密码设置成只有数字的
  • 如何设置令oracle RH开机自动启动============>>??
  • Oracle10g自动归档设置
  • Oracle全文索引设置
  • Oracle数据库设置任务计划备份一周的备份记录
  • 要装oracle,设置好环境变量。之后就啥命令也用不了了
  • Linux下安装ORACLE 10g前的系统设置脚本
  • Linux下设置Oracle 10g 服务以及实例自动启动
  • oracle客户端环境变量设置的问题
  • Linux Oracle 设置LOCK_SGA
  • Oracle客户端 NLS_LANG 的设置方法
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Oracle 12c发布简单介绍及官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • sqlserver iis7站长之家
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • Oracle 数据库开发工具 Oracle SQL Developer
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • Oracle 数据库(oracle Database)性能调优技术详解
  • Linux /$ORACLE_HOME $ORACLE_HOME
  • ORACLE日期相关操作
  • Linux系统下Oracle的启动与Oracle监听的启动
  • ORACLE数据库常用字段数据类型介绍
  • 请问在solaris下安装ORACLE,用root用户和用oracle用户安装有什么区别么?
  • Oracle 12c的九大最新技术特性介绍
  • 网间Oracle的连接,远程连接Oracle服务器??
  • ORACLE中DBMS_RANDOM随机数生成包
  • 请教:.profile中:if [ -d /opt/oracle/db01/app/oracle/product/9.2.0 ]是什么意思?


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3