mysql主键自增为什么在插入的时候还要自己写主键值_Mysql 主键自增插入数据问题...

MySQL数据库表中有自增主键ID,当用SQL插入语句中插入语句带有ID列值记录的时候;

如果指定了该列的值,则新插入的值不能和已有的值重复,而且必须大于其中最大的一个值;

也可以不指定该列的值,只将其他列的值插入,让ID还是按照MySQL自增自己填;

具体:

1.创建数据库

create table if not exists userInfo (

id int PRIMARY KEY AUTO_INCREMENT,

name varchar(50) NOT NULL,

password varchar(50) NOT NULL

);

1

2

3

4

5

2.插入数据记录

insert into userInfo values(1,'aaa','1212');

1

当数据表中有自增长主键时,当用SQL插入语句中插入语句带有ID列值记录的时候;

如果指定了该列的值,则新插入的值不能和已有的值重复,而且必须大于其中最大的一个值;

也可以不指定该列的值,只将其他列的值插入,让ID还是按照MySQL自增自己填;

这种情况在进行插入的时候,两种解决方法:

①可以把id的值设置为null或者0,这样子mysql都会自己做处理

②手动指定需要插入的列,不插入这一个字段的数据!

#方法①:

insert into userInfo values(null,'ddf','8979');

insert into userInfo values(0,'ddf','8979');

1

2

3

#方法②:

insert into userInfo(name,password) values('ddf','8979');

MySQL中,主键自增是一种常见的用于给表添加唯一标识的方法。当插入数据时,可以通过两种方式处理主键自增。 第一种方法是将主键的值设置为null或0,这样MySQL自动主键生成一个唯一的自增值。例如,可以使用以下语句插入数据: ``` insert into userInfo values(null,'ddf','8979'); ``` 或 ``` insert into userInfo values(0,'ddf','8979'); ``` 第二种方法是手动指定需要插入的列,不插入主键的值。例如,可以使用以下语句插入数据: ``` insert into userInfo(name,password) values('ddf','8979'); ``` 无论使用哪种方法,MySQL都会根据自增规则为主键生成唯一的值,并将其插入到表中。这样可以确保每个插入的记录都有唯一的标识值。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Mysql 主键自增](https://blog.csdn.net/qq_41169544/article/details/128920764)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [Mysql 主键自增插入数据问题](https://blog.csdn.net/weixin_36212560/article/details/113122110)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值