如何设置 MySQL 表中从 1001 开始的“id”列的初始值?
我想做一个插入"INSERT INTO users (name, email) VALUES ('{$name}', '{$email}')";
没有指定 id 列的初始值。
如何设置 MySQL 表中从 1001 开始的“id”列的初始值?
我想做一个插入"INSERT INTO users (name, email) VALUES ('{$name}', '{$email}')";
没有指定 id 列的初始值。
用这个:
ALTER TABLE users AUTO_INCREMENT=1001;
或者如果您还没有添加 id 列,也添加它
ALTER TABLE users ADD id INT UNSIGNED NOT NULL AUTO_INCREMENT,
ADD INDEX (id);
第 1 步,创建您的表:
create table penguins(
my_id int(16) auto_increment,
skipper varchar(4000),
PRIMARY KEY (my_id)
)
第二步,设置自增主键的起始编号:
ALTER TABLE penguins AUTO_INCREMENT=1001;
第 3 步,插入一些行:
insert into penguins (skipper) values("We need more power!");
insert into penguins (skipper) values("Time to fire up");
insert into penguins (skipper) values("kowalski's nuclear reactor.");
第 4 步,解释输出:
select * from penguins
印刷:
'1001', 'We need more power!'
'1002', 'Time to fire up'
'1003', 'kowalski\'s nuclear reactor'
MySQL 工作台
如果你想避免写sql,你也可以在MySQL Workbench中通过右键单击表来完成,在菜单中选择“Alter Table ...”。
当表结构视图打开时,转到选项卡“选项”(在视图的底部),并将“自动增量”字段设置为下一个自动增量数字的值。
完成所有更改后,不要忘记点击“应用”。
PhpMyAdmin:
如果您使用的是 phpMyAdmin,您可以单击左侧导航中的表格,转到“操作”选项卡并在表格选项下更改 AUTO_INCREMENT 值,然后单击确定。
首先,您需要添加自动增量列
alter table users add column id int(5) NOT NULL AUTO_INCREMENT FIRST
这个查询首先是添加列。现在您必须重置自动增量初始值。所以使用这个查询
alter table users AUTO_INCREMENT=1001
现在您的表以 1001 开头
您也可以在create table
语句中设置它。
`CREATE TABLE(...) AUTO_INCREMENT=1000`
使用 CREATE TABLE 语句
CREATE TABLE my_table (
id INT UNSIGNED NOT NULL AUTO_INCREMENT,
name VARCHAR(100) NOT NULL,
PRIMARY KEY (id)
) AUTO_INCREMENT = 100;
或使用 ALTER TABLE 语句
ALTER TABLE my_table AUTO_INCREMENT = 200;
为此,您必须设置AUTO_INCREMENT
值
ALTER TABLE tablename AUTO_INCREMENT = <INITIAL_VALUE>
例子
ALTER TABLE tablename AUTO_INCREMENT = 101
此外,在PHPMyAdmin中,您可以从左侧选择表格(表格列表),然后前往那里执行此操作。
操作选项卡->表选项->AUTO_INCREMENT。
现在,设置您的值,然后按表选项框x 下的执行。
设置全局 auto_increment_offset=1;
设置全局 auto_increment_increment=5;
auto_increment_increment:连续列值之间的间隔
auto_increment_offset:确定 AUTO_INCREMENT 列值的起点。默认值为 1。