求一sql【谢谢】 - MS-SQL Server / 基础类
需求如下:
a表:
p_id status
1 0
2 0
b表
rec_id pid purchase_qty receive_qty flag
1 1 10 10 0
2 1 1000 1000 0
3 2 25 10 1
4 2 25 25 0
想得到如下的结果:
1.如果b表中的purchase_qty=receive_qty,且b表中的pid关联a表中的p_id,当a表中所有在b表中的pid=1且purchase_qty与receive_qty相同时,更新a表中的status为1
2.如果B表中的flag为1的话,表示这条记录也完成了,不需要考虑purchase_qty=receive_qty这样的条件,也将a表中的status更新为1
谢谢大家乐
这么快就沉了,up
SQL code:
update @ta
set status=1
from @ta a,@tb b
where a.p_id=b.pid
and (purchase_qty=receive_qty or flag=1)
??
SQL code:
update a表 A set status=1 where
exists(select 1 from b表 where A.pid=pid and (purchase_qty=receive_qty or flag=1))
??
SQL code:
update a set status = case when
b.purchase_qty = b.receive_qty and b.pid = 1
相关问答:
执行的顺序:
1)文件浏览框(选择文件使用)
选择好文件后
点击一个导入按钮的时候 ,把上面上传框里的csv文件以一个ID为文件名,上传到**/**文件夹下
2)读取这个文件夹下的csv的文件,转换成sql
3 ......
大家帮忙看看这2个sql语句哪个查询的速度更快点。谢谢帮忙。比较着急。在做性能测试。
select * from
表A LEFT OUTER JOIN 表B ON (表A.id || ' ' =表B.id) ,表C , 表D, 表E
Where其他条件
select * ......
直接启动 点了等一会儿就没反应了 去服务那里启动会出现如下提示
出现“本地计算机上的MSSQLSERVER服务启动后又停止了。一些服务自动停止,如果它们没有什么可做的
然后还有什么什么不存在
......
我要得到一个字符串如:
sdfk|||sgts
sdfsfd|||rgreg
wrfw|||sefw
就是要得到|||后面的字符串,有什么函数吗?怎么用呢?谢谢!
SQL code:
select
right(col,len(col)-charindex('|||',col)-2)
f ......