SQL Server使用一个语句块批量插入多条记录的三种方法
我们在日常操作中,免不了对数据库的某张表,一次性的要插入多条记录,但是首先想到的就是复制,粘帖N多重复的INSERTINTO语句,万一某一个少了一个分号,或多个逗号之类的,产生错误,要找起来可就费尽了,既浪费时间,又耽误工作。
除了上面所说的方法外,其实还有二中方法,相比较起来要比之前那个要简洁。
首先是之前那个方法:
INSERTINTOMyTable(ID,NAME)VALUES(1,'123'); INSERTINTOMyTable(ID,NAME)VALUES(2,'456'); INSERTINTOMyTable(ID,NAME)VALUES(3,'789');
第二种方法,使用UNIONALL来进行插入操作:
INSERTINTOMyTable(ID,NAME) SELECT4,'000' UNIONALL SELECT5,'001' UNIONALL SELECT6,'002'
是不是要比第一种方法简单点,据说要比第一种要快!
第三种方法就有点特别了,是SQLServer2008特有的,所以,如果你不是SQLServer2008,就不能使用这种方法了,所以赶快升级吧!体验一下SQLServer2008给我们带了的好处。
INSERTINTOMyTable(ID,NAME) VALUES(7,'003'),(8,'004'),(9,'005')
上面演示了3种不同的方法来向数据库一次插入多条数据,第三种方法看起来比较简洁高效,推荐大家都赶快升级到SQLServer2008吧。