可能第一次接触select...into...from...和insert into...select...有很多人都会误解, 从表面上看都是把相关信息查询出来,然后添加到一个表里,其实还远远没有这么简单,接下来,小猪就用最普通的表述给大家介绍一下这两者间的区别。

步骤/方法

1、首先,我们来看一下insert into select语句,其语法形式为:Insert into Table2(field1,field2,...) select value1,value2,... from Table1。

0db8f13b0b9580c8949fba53a3048a99.png

2、这里的要求就是Table2必须已经存在,如果不存在,系统则会提示对象无效。

053862c0af4e47ee13a0be16ed188d51.png

3、同时因为Table2已经存在,所以我们就可以任意的向Table2中加入符合列类型的内容,当然也包括常量,也许通过下面的图,你就会发现,在导入常量时候的不寻常现象了。

1921cfcd44d0671a9cf53bb05ebe22bb.png

4、接下来说一下select into from 语句,该语法形式为:SELECT vale1, value2 into Table2 from Table1。

b3abe7633d6daf313eb9bb31e65ae4af.png

5、这里要求的是MyTable1不存在,因为在插入的时候,系统会自动创建MyTable1,如果之前MyTable1已经被创建,系统就会提示已经存在表。

2d70715d4121c03cd680b3998404506d.png

6、就是因为这个特性,就会给我们带来很多的方便,首先,我如果只想要MyTable2表中的ID列的话那我只需要将ID列select出来,然后加入到新表中即可。

11e635691ad0e9126a674d440ed0d9fa.png

7、那如果我想要MyTable2中的Name列,那我也仅仅是需要把Name列select出来,然后添加到新表中即可。

2eae2c5bbbc4ddab1d1b4434707beaca.png

END

注意事项

应用范围由实践者自己找到答案~

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐