sqlserver批量更新
① sql 批量更新语句
1.使用存储过程
2.在程序代码里逐条循环执行
这里给出一种更高效、简洁的做法,批量更新SQL ,一句SQL就可以替代麻烦的循环过程,有MS SQLServer、Oracle、DB2下的写法
--关键点:t4和t1是同一个table,primary key肯定也是同一个,
--并以它进行关联,这样在 select语句里即可引用到要update的表的fields
UPDATETable1ASt1
SET(Field1,Field2)=(SELECTField21,Field22
FROMTable2t2
INNERJOINTable3t3
ONt3.Field31=t2.Field23
INNERJOINTable4t4
ONt3.Field32=t4.Filed41
WHEREt2.Field24>=''
ANDt1.fId=t4.fId);
----------------------------MSSQLServer-----------------------------------
UPDATEt1
SETField1=Field21,Field2=Field22
FROMTable2t2
INNERJOINTable3t3
ONt3.Field31=t2.Field23
INNERJOINTable4t4
ONt3.Field32=t4.Filed41
WHERE((t2.Field24>='')
ANDt1.fId=t4.fId);
② sqlserver数据库,批量更新用in不生效。
这跟你的存储过程有关,明显是传进去的id值拼接成了一个字符串,存储过程没处理,导致存储过程真正执行的sql是这样的↓
select * from tb where id in('1002,5008')
看到没,数据库就认为'1002,5008'这个是一个单独的id
把存储过程的sql打印出来看下你就清楚了。
③ sqlserver 批量更新某些行数据等于另一行数据,求教!
这个题目可以采用相关子查询实现:
update aab set pic=(select pic from aab aab1 where aab1.dmlx=aab.dmlx and pic!='0'), place=(select place from aab aab2 where aab2.dmlx=aab.dmlx and place is not null)
④ sqlserver 批量更新某些行数据等于另一行数据,求教
我个人的建议是..把有数据的列..重新导到一张新表 可以用 create table table_name select column_name1,column_name2 from aab;
然后以这张新表为条件.进行更改..
因为你在update的时候..不能用更改的表做为条件...这是语法不允许的...
⑤ sqlserver 批量更新某些行数据等于另一行数据,求教
update table set
pic = (select max(pic) from table where dmix = table.dmix and place != 0 and place is not null)
,place = (select max(place ) from table where dmix = table.dmix and place != 0 and place is not null)
where pic= 0 and place is null
⑥ sql server如何批量更新数据。
update表名setvalue=casewhenid=1then一个值
whenid=2then一个值
whenid=3then一个值elsevalue
end
上边就是举个例子,意思是,当id=1时,把value设定个值,当id=2时,value设定另一个值,依次类推,不需要更改的保留原来的value值,最后以end结尾
⑦ SQLserver 大批量更新插入的时候游标怎么优化
尽量避免使用游标,因为游标的效率较差,如果游标操作的数据超过1万行,那么就应该考虑改写。
使用基于游标的方法之前,应先寻找基于集的解决方案来解决问题,基于集的方法通常更有效。
最好的改进光标性能的技术就是:能避免时就避免使用游标
若有时无法避免使用游标,则可以用如下技巧来优化游标的性能。
(1). 除非必要否则不要使用static/insensitive游标。打开static游标会造成所有的行都被拷贝到临时表。这正是为什么它对变化不敏感的原因——它实际上是指向临时数据库表中的一个备份。很自然,结果集越大,声明其上的static游标就会引起越多的临时数据库的资源争夺问题。
(2). 除非必要否则不要使用keyset游标。和static游标一样,打开keyset游标会创建临时表。虽然这个表只包括基本表的一个关键字列(除非不存在唯一关键字),但是当处理大结果集时还是会相当大的。
(3). 当处理单向的只读结果集时,使用fast_forward代替forward_only。使用fast_forward定义一个forward_only,则read_only游标具有一定的内部性能优化。
(4). 使用read_only关键字定义只读游标。这样可以防止意外的修改,并且让服务器了解游标移动时不会修改行。
(5). 小心事务处理中通过游标进行的大量行修改。根据事务隔离级别,这些行在事务完成或回滚前会保持锁定,这可能造成服务器上的资源争夺。
(6). 小心动态光标的修改,尤其是建在非唯一聚集索引键的表上的游标,因为他们会造成“Halloween”问题——对同一行或同一行的重复的错误的修改。因为SQL Server在内部会把某行的关键字修改成一个已经存在的值,并强迫服务器追加下标,使它以后可以再结果集中移动。当从结果集的剩余项中存取时,又会遇到那一行,然后程序会重复,结果造成死循环。
(7). 对于大结果集要考虑使用异步游标,尽可能地把控制权交给调用者。当返回相当大的结果集到可移动的表格时,异步游标特别有用,因为它们允许应用程序几乎马上就可以显示行
⑧ sql 批量更新数据
给你写个sqlserver的,其他数据库的话另说
1
update table2 set pwd=table1.ip from table1 inner join table2 on table1.username=table2.username
⑨ sqlserver 关联表批量更新多行
update a set a.name1 = b.name1, a.name2=b.name2
from 表A a, 表B b where a.id=b.id
⑩ sql可以两个表一起更新数据吗
如果两个表有关联的话是可以的,比如A表的id和b表的b_id外键关系就可以
update a left join b on a.id = b.b_id set a.name = '',b.name='' (where条件)