В MySQL у меня есть таблица, и я хочу установить значение auto_increment равным 5 вместо 1. Возможно ли это и какой оператор запроса это делает?

292
John Jones 9 Июн 2009 в 19:01

7 ответов

Лучший ответ

Вы можете использовать ALTER TABLE, чтобы изменить начальное значение auto_increment:

ALTER TABLE tbl AUTO_INCREMENT = 5;

Дополнительные сведения см. В справочнике по MySQL.

556
Eric Leschinski 18 Авг 2014 в 14:54

Да, вы можете использовать оператор ALTER TABLE t AUTO_INCREMENT = 42. Однако вы должны знать, что это приведет к перестройке всей вашей таблицы, по крайней мере, с InnoDB и некоторыми версиями MySQL. Если у вас уже есть набор данных с миллионами строк, это может занять очень много времени .

По моему опыту, лучше сделать следующее:

BEGIN WORK;
-- You may also need to add other mandatory columns and values
INSERT INTO t (id) VALUES (42);
ROLLBACK;

Таким образом, даже если вы откатываете транзакцию, MySQL сохранит значение автоинкремента, и изменение будет применено мгновенно.

Вы можете проверить это, выполнив инструкцию SHOW CREATE TABLE t. Тебе следует увидеть:

> SHOW CREATE TABLE t \G
*************************** 1. row ***************************
       Table: t
Create Table: CREATE TABLE `t` (
...
) ENGINE=InnoDB AUTO_INCREMENT=43 ...
102
Cosimo 11 Май 2017 в 11:05

Как автоматически увеличить на единицу, начиная с 10 в MySQL:

create table foobar(
  id             INT PRIMARY KEY AUTO_INCREMENT,
  moobar         VARCHAR(500)
); 
ALTER TABLE foobar AUTO_INCREMENT=10;

INSERT INTO foobar(moobar) values ("abc");
INSERT INTO foobar(moobar) values ("def");
INSERT INTO foobar(moobar) values ("xyz");

select * from foobar;

'10', 'abc'
'11', 'def'
'12', 'xyz'

Это автоматически увеличивает столбец id на единицу, начиная с 10.

Автоматическое увеличение в MySQL на 5, начиная с 10:

drop table foobar
create table foobar(
  id             INT PRIMARY KEY AUTO_INCREMENT,
  moobar         VARCHAR(500)
); 
SET @@auto_increment_increment=5;
ALTER TABLE foobar AUTO_INCREMENT=10;

INSERT INTO foobar(moobar) values ("abc");
INSERT INTO foobar(moobar) values ("def");
INSERT INTO foobar(moobar) values ("xyz");

select * from foobar;
'11', 'abc'
'16', 'def'
'21', 'xyz'

Это автоматически увеличивает столбец id на 5 каждый раз, начиная с 10.

15
Eric Leschinski 12 Окт 2014 в 13:35

Процедура автоматического исправления значения AUTO_INCREMENT таблицы

DROP PROCEDURE IF EXISTS update_auto_increment;
DELIMITER //
CREATE PROCEDURE update_auto_increment (_table VARCHAR(64))
BEGIN
    DECLARE _max_stmt VARCHAR(1024);
    DECLARE _stmt VARCHAR(1024);    
    SET @inc := 0;

    SET @MAX_SQL := CONCAT('SELECT IFNULL(MAX(`id`), 0) + 1 INTO @inc FROM ', _table);
    PREPARE _max_stmt FROM @MAX_SQL;
    EXECUTE _max_stmt;
    DEALLOCATE PREPARE _max_stmt;

    SET @SQL := CONCAT('ALTER TABLE ', _table, ' AUTO_INCREMENT =  ', @inc);
    PREPARE _stmt FROM @SQL;
    EXECUTE _stmt;
    DEALLOCATE PREPARE _stmt;
END//
DELIMITER ;

CALL update_auto_increment('your_table_name')
6
Zhitko Vladimir 29 Авг 2014 в 16:22

Если вам нужна эта процедура для имен полей переменных вместо id, это может быть полезно:

DROP PROCEDURE IF EXISTS update_auto_increment;
DELIMITER //
CREATE PROCEDURE update_auto_increment (_table VARCHAR(128), _fieldname VARCHAR(128))
BEGIN
    DECLARE _max_stmt VARCHAR(1024);
    DECLARE _stmt VARCHAR(1024);    
    SET @inc := 0;

    SET @MAX_SQL := CONCAT('SELECT IFNULL(MAX(',_fieldname,'), 0) + 1 INTO @inc FROM ', _table);
    PREPARE _max_stmt FROM @MAX_SQL;
    EXECUTE _max_stmt;
    DEALLOCATE PREPARE _max_stmt;

    SET @SQL := CONCAT('ALTER TABLE ', _table, ' AUTO_INCREMENT =  ', @inc);
    PREPARE _stmt FROM @SQL;
    EXECUTE _stmt;
    DEALLOCATE PREPARE _stmt;
END //
DELIMITER ;

CALL update_auto_increment('your_table_name', 'autoincrement_fieldname');
3
Thomas K. 9 Фев 2016 в 11:41

Вы также можете сделать это с помощью phpmyadmin. Просто выберите таблицу и переходите к действиям. И измените параметры Автоинкремента под таблицей. Не забудьте нажать на пуск Автоинкремент в phpmyadmin

2
North-Wind 25 Сен 2017 в 19:52

Просто экспортируйте таблицу с данными .. затем скопируйте ее sql как

CREATE TABLE IF NOT EXISTS `employees` (
  `emp_badgenumber` int(20) NOT NULL AUTO_INCREMENT,
  `emp_fullname` varchar(100) NOT NULL,
  `emp_father_name` varchar(30) NOT NULL,
  `emp_mobile` varchar(20) DEFAULT NULL,
  `emp_cnic` varchar(20) DEFAULT NULL,
  `emp_gender` varchar(10) NOT NULL,
  `emp_is_deleted` tinyint(4) DEFAULT '0',
  `emp_registration_date` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
  `emp_overtime_allowed` tinyint(4) DEFAULT '1',
  PRIMARY KEY (`emp_badgenumber`),
  UNIQUE KEY `bagdenumber` (`emp_badgenumber`),
  KEY `emp_badgenumber` (`emp_badgenumber`),
  KEY `emp_badgenumber_2` (`emp_badgenumber`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=111121326 ;

Теперь измените значение автоматического увеличения и выполните sql.

-2
rink.attendant.6 14 Июн 2014 в 08:05