В MySQL у меня есть таблица, и я хочу установить значение auto_increment
в 5
вместо 1
. Возможно ли это, и что делает запрос запроса?
Изменить стартовый номер автоинкремента?
Ответ 1
Вы можете использовать ALTER TABLE
, чтобы изменить начальное значение auto_increment:
ALTER TABLE tbl AUTO_INCREMENT = 5;
Подробнее см. ссылку на MySQL.
Ответ 2
Да, вы можете использовать оператор 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 ...
Ответ 3
Как автоматическое увеличение на единицу, начиная с 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'
Это автоматически увеличивает столбец идентификатора на единицу, начиная с 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'
Это автоматически увеличивает каждый столбец идентификатора на 5, начиная с 10.
Ответ 4
Процедура автоматического исправления значения 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')
Ответ 5
Если вам нужна эта процедура для переменных fieldnames вместо 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');
Ответ 6
Вы также можете сделать это, используя phpmyadmin. Просто выберите таблицу, а не перейдите к действиям. И измените опцию Auto increment ниже table. Не забудьте нажать на кнопку запуска
Ответ 7
просто экспортируйте таблицу с данными. затем скопируйте его 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.