欢迎来到天天文库
浏览记录
ID:34744170
大小:62.68 KB
页数:4页
时间:2019-03-10
《几个常见数据库关于主键自动增加的设置》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
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;
此文档下载收益归作者所有