自增列和insert into的问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了自增列和insert into的问题相关的知识,希望对你有一定的参考价值。

我设计了一张表有3个列:id,num,id2,其中id和id2已经设置成不允许为空,且自增,我想用insert into往里面插数据,三个列都是int类型的,表叫table1,谁给我个sql语句的例子

参考技术A 1,往sqlserver 表中插入:num=1的记录
insert into table1(num) values(1)
id,id2字段自增可以不用赋值,插入后数据库自动添加自增值到这两列;

2,自己可以多试验,这是很简单的语句
参考技术B 这个表,如果如你所设计,那么id和id2将是同样的值,从而丧失了id2字段的意义。请仔细考虑。
另外,
1,往sqlserver 表中插入:num=1的记录
insert into table1(num) values(1)
id,id2字段自增可以不用赋值,插入后数据库自动添加自增值到这两列;
的回答正确。本回答被提问者采纳

mysql insert update delete

insert

insert [into] t [(col_name,...)] values(v1,v2...)

如果省略了列名,那么values里必须有所有列的值,自增列的值为null

如果指定了部分列名,其他的列必须允许为null或指定了默认值

 

连续插入

insert into table(name, address, zip)

values(‘zhangsan‘, ‘江苏‘, ‘222100‘),

(‘lisi‘, ‘上海‘, ‘220300‘);

 

插入select的结果

insert into customers(id,name,email) select uid,uname,uemail from custnew;

列名不需要相同,重要的是列的位置,将select的第k列插入到insert的第k列

 

降低插入语句的优先级,对update和delete同样适用

insert low priority into..

 

唯一索引,记录重复时可选择只更新指定字段,或者保留老记录,或者用新纪录整条替换老记录

只更新指定字段:on duplicate key update

insert into table(a,b)

select c,d from t

on duplicate key update b=values(a)+values(b) //values(b)是想插入的新记录里b的值

保留老记录:insert ignore into

替换老记录:replace into

 

update

update t set name=‘zhangsan‘, email = ‘sdf@qq.com‘ where id=1;

update a inner join b on a.id=b.uid set type = utype; 多表更新

update ignore t... 某行发生错误,其它行继续更新

update a, b set a.title=b.title, a.name=b.name where a.id=b.id 用另一个表的数据更新

 

delete

delete from t where id=1;

delete t1 from t1 left join (select ..) as t2 on t1.id=t2.id where t2.name=‘abc‘; 多表删除

如果想删除所有行,用truncate table语句更快,实际上是删除原来的表并新建一个表。

 

以上是关于自增列和insert into的问题的主要内容,如果未能解决你的问题,请参考以下文章

MySQL插入自增列数据的问题

mysql如何增加一自增列

怎么重置mysql的自增列AUTO

mysql主见自增,新增对象之后如何获取自增列

怎么重置mysql的自增列AUTO_INCREMENT初时值

在SQL查询结果中添加自增列的两种方法