几个常见数据库关于主键自动增加的设置

几个常见数据库关于主键自动增加的设置

ID:34744170

大小:62.68 KB

页数:4页

时间:2019-03-10

几个常见数据库关于主键自动增加的设置_第1页
几个常见数据库关于主键自动增加的设置_第2页
几个常见数据库关于主键自动增加的设置_第3页
几个常见数据库关于主键自动增加的设置_第4页
资源描述:

《几个常见数据库关于主键自动增加的设置》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、几个常见数据库关于主键自动增加的设置1、把主键定义为自动增长标识符类型在mysql中,如果把表的主键设为auto_increment类型,数据库就会自动为主键赋值。例如:createtablecustomers(idintauto_incrementprimarykeynotnull,namevarchar(15));insertintocustomers(name)values("name1"),("name2");selectidfromcustomers;以上sql语句先创建了customers表,然后插入两条记录,在插入时仅仅设定了name字段的值。最后查询表中

2、id字段,查询结果为:id12由此可见,一旦把id设为auto_increment类型,mysql数据库会自动按递增的方式为主键赋值。在MSSQLServer中,如果把表的主键设为identity类型,数据库就会自动为主键赋值。例如:createtablecustomers(idintidentity(1,1)primarykeynotnull,namevarchar(15));insertintocustomers(name)values("name1"),("name2");selectidfromcustomers;查询结果和mysql的一样。由此可见,一旦把id

3、设为identity类型,MSSQLServer数据库会自动按递增的方式为主键赋值。identity包含两个参数,第一个参数表示起始值,第二个参数表示增量。2、从序列中获取自动增长的标识符在Oracle中,可以为每张表的主键创建一个单独的序列,然后从这个序列中获取自动增加的标识符,把它赋值给主键。例如一下语句创建了一个名为customer_id_seq的序列,这个序列的起始值为1,增量为2。createsequencecustomer_id_seqincrementby2startwith1一旦定义了customer_id_seq序列,就可以访问序列的curval和ne

4、xtval属性。curval:返回序列的当前值nextval:先增加序列的值,然后返回序列值以下sql语句先创建了customers表,然后插入两条记录,在插入时设定了id和name字段的值,其中id字段的值来自于customer_id_seq序列。最后查询customers表中的id字段。createtablecustomers(idintprimarykeynotnull,namevarchar(15));insertintocustomersvalues(customer_id_seq.curval,"name1"),(customer_id_seq.nextva

5、l,"name2");selectidfromcustomers;如果在oracle中执行以上语句,查询结果为:id13Oracle数据库主键自增怎么设置?1.增加一个序列号2.增加一个触发器,如果是insert,则取序列号值,赋予主键列追问能写一下语法吗?回答比如表名:tab,主键为:id1.增加一个序列号:createsequenceseq_tab2.增加一个触发器,如果是insert,则取序列号值,赋予主键列CREATEORREPLACETRIGGERTRI_tabBEFOREINSERTONtabFOREACHROWDECLARE--LOCALVARIABLES

6、HEREBEGINIF:NEW.idISNULLTHENSELECTSEQ_tab.NEXTVALINTO:NEW.idFROMDUAL;ENDIF;ENDTRI_tab;第二步:创建一个基于该表的beforeinsert触发器,在触发器中使用该SEQUENCEcreateorreplacetriggerbef_ins_t_country_definebeforeinsertont_country_defineforeachrowbeginnew.country_id=s_country_id.nextval;end;

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。