欢迎来到天天文库
浏览记录
ID:42578478
大小:35.45 KB
页数:4页
时间:2019-09-18
《MySql 主键自动增长》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、MySql主键自动增长Mysql,SqlServer,Oracle主键自动增长设置1、把主键定义为自动增长标识符类型MySql在mysql中,如果把表的主键设为auto_increment类型,数据库就会自动为主键赋值。例如:createtablecustomers(idintauto_incrementprimarykeynotnull,namevarchar(15));insertintocustomers(name)values("name1"),("name2");selectidfromcustomers;以上sql语句先创建了customer
2、s表,然后插入两条记录,在插入时仅仅设定了name字段的值。最后查询表中id字段,查询结果为:由此可见,一旦把id设为auto_increment类型,mysql数据库会自动按递增的方式为主键赋值。SqlServer在MSSQLServer中,如果把表的主键设为identity类型,数据库就会自动为主键赋值。例如:createtablecustomers(idintidentity(1,1)primarykeynotnull,namevarchar(15));insertintocustomers(name)values('name1'),('name2
3、');selectidfromcustomers;注意:在sqlserver中字符串用单引号扩起来,而在mysql中可以使用双引号。查询结果和mysql的一样。由此可见,一旦把id设为identity类型,MSSQLServer数据库会自动按递增的方式为主键赋值。identity包含两个参数,第一个参数表示起始值,第二个参数表示增量。以前经常会碰到这样的问题,当我们删除了一条自增长列为1的记录以后,再次插入的记录自增长列是2了。我们想在插入一条自增长列为1的记录是做不到的。今天跟同事讨论的时候发现可以通过设置SETIDENTITY_INSERT4、e_name>ON;来取消自增长,等我们插入完数据以后在关闭这个功能。实验如下:useTESTDB2--step1:创建表createtablecustomers(idintidentityprimarykeynotnull,namevarchar(15));--step2:执行插入操作insertintocustomers(id,name)values(1,'name1');--报错:Anexplicitvaluefortheidentitycolumnintable'customers'canonlybespecifiedwhenacolumnlis5、tisusedandIDENTITY_INSERTisON.--step3:放开主键列的自增长SETIDENTITY_INSERTcustomersON;--step4:插入两条记录,主键分别为1和3。插入成功insertintocustomers(id,name)values(1,'name1');insertintocustomers(id,name)values(3,'name1');--step5:再次插入一个主键为2的记录。插入成功insertintocustomers(id,name)values(2,'name1');--step6:插入重6、复主键,--报错:ViolationofPRIMARYKEYconstraint'PK__customer__3213E83F00551192'.Cannotinsertduplicatekeyinobject'dbo.customers'.insertintocustomers(id,name)values(3,'name1');--step7:关闭IDENTITY_INSERTSETIDENTITY_INSERTcustomersOFF;2、从序列中获取自动增长的标识符Oracle在Oracle中,可以为每张表的主键创建一个单独的序列,然后从这个序列7、中获取自动增加的标识符,把它赋值给主键。例如一下语句创建了一个名为customer_id_seq的序列,这个序列的起始值为1,增量为2。createsequencecustomer_id_seqincrementby2startwith1一旦定义了customer_id_seq序列,就可以访问序列的curval和nextval属性。·curval:返回序列的当前值·nextval:先增加序列的值,然后返回序列值以下sql语句先创建了customers表,然后插入两条记录,在插入时设定了id和name字段的值,其中id字段的值来自于customer_id_8、seq序列。最后查询customers表中的id字段。createtablecu
4、e_name>ON;来取消自增长,等我们插入完数据以后在关闭这个功能。实验如下:useTESTDB2--step1:创建表createtablecustomers(idintidentityprimarykeynotnull,namevarchar(15));--step2:执行插入操作insertintocustomers(id,name)values(1,'name1');--报错:Anexplicitvaluefortheidentitycolumnintable'customers'canonlybespecifiedwhenacolumnlis
5、tisusedandIDENTITY_INSERTisON.--step3:放开主键列的自增长SETIDENTITY_INSERTcustomersON;--step4:插入两条记录,主键分别为1和3。插入成功insertintocustomers(id,name)values(1,'name1');insertintocustomers(id,name)values(3,'name1');--step5:再次插入一个主键为2的记录。插入成功insertintocustomers(id,name)values(2,'name1');--step6:插入重
6、复主键,--报错:ViolationofPRIMARYKEYconstraint'PK__customer__3213E83F00551192'.Cannotinsertduplicatekeyinobject'dbo.customers'.insertintocustomers(id,name)values(3,'name1');--step7:关闭IDENTITY_INSERTSETIDENTITY_INSERTcustomersOFF;2、从序列中获取自动增长的标识符Oracle在Oracle中,可以为每张表的主键创建一个单独的序列,然后从这个序列
7、中获取自动增加的标识符,把它赋值给主键。例如一下语句创建了一个名为customer_id_seq的序列,这个序列的起始值为1,增量为2。createsequencecustomer_id_seqincrementby2startwith1一旦定义了customer_id_seq序列,就可以访问序列的curval和nextval属性。·curval:返回序列的当前值·nextval:先增加序列的值,然后返回序列值以下sql语句先创建了customers表,然后插入两条记录,在插入时设定了id和name字段的值,其中id字段的值来自于customer_id_
8、seq序列。最后查询customers表中的id字段。createtablecu
此文档下载收益归作者所有