当前位置:   article > 正文

mysql设置除主键外自增_如何给除了主键外的字段设置自增?

mysql设置非主键字段自增

如何给除了主键外的字段设置自增?

一个表有主键,是自增的,

我想给表的另一个字段设置主键,设置成自增从10000开始自增,

在网上找了好多资料都是设置主键的,没有其他字段的,想问下如何写?

一个表只能有一个 自增键(有索引即可

一般设为唯一索引

,不要求主键)。

如果你的主键已经是自增了,那么这个表不能再有自增键了。

如果你的主键是非自增的,那么可以设置一个

ALTER TABLE `weibo`

ADD COLUMN `serial`  bigint UNSIGNED NOT NULL AUTO_INCREMENT AFTER `id`,

ADD INDEX `serial` (`serial`) USING BTREE,

AUTO_INCREMENT=94381;

mysql中只能设置一列为自增长,这一列可以是主键,也可以不是主键,如果不是主键,则必须将其设置为一种键(key,即索引)。自增的开始值为表属性,不是字段属性,所以需要在表属性中设置,如要设置自增开始值为10000

create table test(

id int not null,

noid int not null auto_increment,

primary key(id), --如果主键设置了自增长,那么其他列就不能在设置自增长了

key(noid) -- 如果给其他列设置自增长,那么必须为其创建一个索引,索引类型有很多,自行查资料

)engine=xxx auto_increment=10000;

可以通过创建一个

insert

触发器解决,即使主键有自增也无妨。

比如表名

tab1

要求自增字段

ac

CREATE TRIGGER `tab1_before_insert` BEFORE INSERT ON `tab1` FOR EACH ROW BEGIN

SET @x:=(SELECT MAX(ac) FROM tab1);

SET NEW.ac = @x + 1;

END

在表上加个触发器:

CREATE TRIGGER tri_test

BEFORE INSERT

ON test –test要操作的表

FOR EACH ROW

declare

v_test varchar(30);

BEGIN

if inserting then

select seq_test.nextval into v_test from dual;   --设立了一个序列,自动获取序列下一个值:

:new.col_test:= v_test;--赋值给自增字段

end if;

END;

可以把时间戳当主键用,这玩意本来就是自增的,然后你再设置另一个字段自增……如果插入速度不是很快的话……一般没人这么用吧……

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/人工智能uu/article/detail/912128
推荐阅读
相关标签
  

闽ICP备14008679号