如何使用自增列(字段)向MySQL插入数据?

问题描述 投票:0回答:7

我创建了一个带有主键的表并启用了

AUTO_INCREMENT

CREATE TABLE IF NOT EXISTS test.authors (
    hostcheck_id INT PRIMARY KEY AUTO_INCREMENT,
    instance_id INT,
    host_object_id INT,
    check_type INT,
    is_raw_check INT,
    current_check_attempt INT,
    max_check_attempts INT,
    state INT,
    state_type INT,
    start_time datetime,
    start_time_usec INT,
    end_time datetime,
    end_time_usec INT,
    command_object_id INT,
    command_args VARCHAR(25),
    command_line VARCHAR(100),
    timeout int,
    early_timeout INT,
    execution_time DEC(18,5),
    latency DEC(18,3),
    return_code INT,
    output VARCHAR(50),
    long_output VARCHAR(50),
    perfdata VARCHAR(50)
);

然后,在下面的查询中,我尝试了“”和“1”作为第一个值,但它不起作用:

INSERT INTO  test.authors VALUES ('1','1','67','0','0','1','10','0','1',
'2012-01-03 12:50:49','108929','2012-01-03 12:50:59','198963','21','',
'/usr/local/nagios/libexec/check_ping  5','30','0','4.04159','0.102','1',
'PING WARNING -DUPLICATES FOUND! Packet loss = 0%, RTA = 2.86 ms','',
'rta=2.860000m=0%;80;100;0'); 

那么,如何使用自增列(字段)向MySQL插入数据?

mysql sql database insert auto-increment
7个回答
180
投票

如果您希望它被自动神奇地分配,请将自动增量字段设置为 NULL 或 0...


84
投票

为了利用列的自动递增功能,插入行时不要为该列提供值。数据库将为您提供一个值。

INSERT INTO test.authors (
   instance_id,host_object_id,check_type,is_raw_check,
   current_check_attempt,max_check_attempts,state,state_type,
   start_time,start_time_usec,end_time,end_time_usec,command_object_id,
   command_args,command_line,timeout,early_timeout,execution_time,
   latency,return_code,output,long_output,perfdata
) VALUES (
   '1','67','0','0','1','10','0','1','2012-01-03 12:50:49','108929',
   '2012-01-03 12:50:59','198963','21','',
   '/usr/local/nagios/libexec/check_ping  5','30','0','4.04159',
   '0.102','1','PING WARNING -DUPLICATES FOUND! Packet loss = 0%, RTA = 2.86 ms',
   '','rta=2.860000m=0%;80;100;0'
);

36
投票

default
关键字对我有用:

mysql> insert into user_table (user_id, ip, partial_ip, source, user_edit_date, username) values 
(default, '39.48.49.126', null, 'user signup page', now(), 'newUser');
---
Query OK, 1 row affected (0.00 sec)

我在跑

mysql --version
5.1.66:

mysql  Ver 14.14 Distrib **5.1.66**, for debian-linux-gnu (x86_64) using readline 6.1

12
投票

查看this post

根据它

没有为 AUTO_INCREMENT 列指定值,所以 MySQL 自动分配序列号。你也可以明确地 将 NULL 或 0 分配给该列以生成序列号。


11
投票

我在这里看到三种可能性,它们将帮助您插入表格而不会造成一团糟,但是 “指定” AUTO_INCREMENT 列的值,因为您提供了所有值,您可以执行以下任一选项.

第一种方法(提供NULL):

INSERT INTO test.authors VALUES (
 NULL,'1','67','0','0','1','10','0','1','2012-01-03 12:50:49','108929',
 '2012-01-03 12:50:59','198963','21','',
 '/usr/local/nagios/libexec/check_ping  5','30','0','4.04159',
 '0.102','1','PING WARNING -DUPLICATES FOUND! Packet loss = 0%, RTA = 2.86 ms',
 '','rta=2.860000m=0%;80;100;0'
);

第二种方法(提供'' {单引号/撇号}虽然它会给你一个警告):

INSERT INTO test.authors VALUES (
 '','1','67','0','0','1','10','0','1','2012-01-03 12:50:49','108929',
 '2012-01-03 12:50:59','198963','21','',
 '/usr/local/nagios/libexec/check_ping  5','30','0','4.04159',
 '0.102','1','PING WARNING -DUPLICATES FOUND! Packet loss = 0%, RTA = 2.86 ms',
 '','rta=2.860000m=0%;80;100;0'
);

第三种方法(提供default):

INSERT INTO test.authors VALUES (
 default,'1','67','0','0','1','10','0','1','2012-01-03 12:50:49','108929',
 '2012-01-03 12:50:59','198963','21','',
 '/usr/local/nagios/libexec/check_ping  5','30','0','4.04159',
 '0.102','1','PING WARNING -DUPLICATES FOUND! Packet loss = 0%, RTA = 2.86 ms',
 '','rta=2.860000m=0%;80;100;0'
);

插入该表时,只要您按照创建表时定义的相同顺序包含所有值,这些示例之一就足够了。


0
投票

对于自增列(字段)

CREATE TABLE person (
    id INT NOT NULL AUTO_INCREMENT,
    first_name VARCHAR(50) NOT NULL,
    last_name VARCHAR(50) NOT NULL,
    PRIMARY KEY (id)
);

您可以使用

NULL
0
插入自动递增的值,如下所示:

                        -- Here
INSERT INTO person VALUES (NULL, "John", "Smith")
                        -- Here
INSERT INTO person VALUES (0, "John", "Smith")

-1
投票

我使用类似这样的方法在我的 SQL 请求中只键入值。 我的案例栏目太多了,懒惰

insert into my_table select max(id)+1, valueA, valueB, valueC.... from my_table; 
© www.soinside.com 2019 - 2024. All rights reserved.