- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
几个常见数据库关于主键自动增加的设置
几个常见数据库关于主键自动增加的设置
1、把主键定义为自动增长标识符类型在mysql中,如果把表的主键设为auto_increment类型,数据库就会自动为主键赋值。例如:create table customers(id int auto_increment primary key not null, name varchar(15));insert into customers(name) values(name1),(name2);select id from customers;以上sql语句先创建了customers表,然后插入两条记录,在插入时仅仅设定了name字段的值。最后查询表中id字段,查询结果为:id12由此可见,一旦把id设为auto_increment类型,mysql数据库会自动按递增的方式为主键赋值。在MS SQLServer中,如果把表的主键设为identity类型,数据库就会自动为主键赋值。例如:create table customers(id int identity(1,1) primary key not null, name varchar(15));insert into customers(name) values(name1),(name2);select id from customers;查询结果和mysql的一样。由此可见,一旦把id设为identity类型,MS SQLServer数据库会自动按递增的方式为主键赋值。identity包含两个参数,第一个参数表示起始值,第二个参数表示增量。2、从序列中获取自动增长的标识符在Oracle中,可以为每张表的主键创建一个单独的序列,然后从这个序列中获取自动增加的标识符,把它赋值给主键。例如一下语句创建了一个名为customer_id_seq的序列,这个序列的起始值为1,增量为2。create sequence customer_id_seq increment by 2 start with 1一旦定义了customer_id_seq序列,就可以访问序列的curval和nextval属性。curval:返回序列的当前值nextval:先增加序列的值,然后返回序列值以下sql语句先创建了customers表,然后插入两条记录,在插入时设定了id和name字段的值,其中id字段的值来自于customer_id_seq序列。最后查询customers表中的id字段。create table customers(id int primary key not null, name varchar(15));insert into customers values(customer_id_seq.curval, name1),(customer_id_seq.nextval, name2);select id from customers;如果在oracle中执行以上语句,查询结果为:id1
3Oracle数据库主键自增怎么设置?
1. 增加一个序列号2. 增加一个触发器,如果是insert,则取序列号值,赋予主键列
追问
能写一下语法吗?
回答
比如表名:tab,主键为:id1. 增加一个序列号: create sequence seq_tab2. 增加一个触发器,如果是insert,则取序列号值,赋予主键列 CREATE OR REPLACE TRIGGER TRI_tab BEFORE INSERT ON tab FOR EACH ROW DECLARE -- LOCAL VARIABLES HERE BEGIN IF :NEW.id IS NULL THEN SELECT SEQ_tab.NEXTVAL INTO :NEW.id FROM DUAL; END IF;END TRI_tab;
第二步:创建一个基于该表的before insert 触发器,在触发器中使用该SEQUENCE create or replace trigger bef_ins_t_country_define before insert on t_country_define for each row begin new.country_id=s_country_id.nextval; end;
您可能关注的文档
最近下载
- 2025至2030年中国高透明型香烟包装膜数据监测研究报告.docx
- 2025至2030年中国花岗岩行业市场调查研究及投资前景预测报告.docx
- 齐岳山隧道F断层注浆截水帷幕施工技术.docx VIP
- 《光伏电站运行与维护》试题及答案二.docx VIP
- 三机的配套情况.ppt VIP
- 暑假衔接知识点专题13习作(讲义+试题)三升四年级语文(含答案)部编版.pdf VIP
- _第11课互联网服务应用广 课件+2024—2025学年人教版(2024)初中信息科技七年级全一册.pptx VIP
- 齐岳山隧道F11断层注浆截水帷幕施工技术.doc VIP
- 西师大版三年级下册数学填空题完美版.pdf VIP
- 合同管理审计 - 审计.docx VIP
原创力文档


文档评论(0)