php - 如何给除了主键外的字段设置自增?
迷茫
迷茫 2017-04-11 10:10:03
[PHP讨论组]

如何给除了主键外的字段设置自增?
一个表有主键,是自增的,
我想给表的另一个字段设置主键,设置成自增从10000开始自增,
在网上找了好多资料都是设置主键的,没有其他字段的,想问下如何写?

迷茫
迷茫

业精于勤,荒于嬉;行成于思,毁于随。

全部回复(5)
巴扎黑

一个表只能有一个 自增键(有索引即可一般设为唯一索引,不要求主键)。
如果你的主键已经是自增了,那么这个表不能再有自增键了。
如果你的主键是非自增的,那么可以设置一个

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;

怪我咯

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

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号