SQL一条语句更新两个表!

a表有以下字段申请单号(主键)、申请日期、申请状态B表中有以下字段:申请单号(外键)、申请人姓名、申请身份证号、申请状态。现在我想更新身份证号为1的人的申请状态都为2,可... a表有以下字段 申请单号(主键)、申请日期、申请状态
B表中有以下字段:申请单号(外键)、申请人姓名、申请身份证号、申请状态。
现在我想更新身份证号为1的人的申请状态都为2,可以用一条语句实现吗?
这表只是我假设的而已~~我要的SQL语句数据库的结构另论
2楼给的应该不对吧,我要的是同时更改两个表的申请状态为2!
现在只是改a表里的吧?
3楼给的好复杂啊,我看不是很懂,但是我要的只是SQL语句~
很感谢各位,只是只能采纳一个答案!~
不好意思了!

还是谢谢!
展开
 我来答
jacken
2009-08-27
知道答主
回答量:90
采纳率:0%
帮助的人:51.5万
展开全部
首先注意Statement 和PreparedStatement的问题

Statement sm = cn.createStatement(); sm.addBatch(sql1); sm.addBatch(sql2); ... sm.executeBatch()用Statement的好处就是每次可以直接传一个SQL语句进去,不用管那么多。可是在数据量比较大的时候,应该会对效率有影响。不建议使用。

PreparedStatement ps = cn.preparedStatement(sql); { ps.setXXX(1,xxx); ... ps.addBatch(); } ps.executeBatch();PreparedStatement是会预编译的,只要一条SQL,不断动态设值,然后addBatch(),在数据量大的时候比较好,非常建议使用。

还有就是JDBC的驱动问题,很多同志可能还是在用2000的驱动呢,没有用批量更新的程序没有多大问题,可是一旦用了批量更新,出现很多问题,

反正数据库很卡,慢。还可以更新不了哦。

我强烈建议大家更新JDBC驱动。

但是如果出现

SQLServerException: sp_cursoropen/sp_cursorprepare: 该语句参数只能是一个批或带有单个 SELECT 语句的存储过程,且不带 FOR BROWSE、COMPUTE BY 或变量赋值。

应该就是JDBC的版本问题,1.0的驱动有这个问题,好像不支持批量更新,我建议大家使用1.2

我测试过了,完全没有问题!

提供一些数据连接参数

jdbc.driverClassName:com.microsoft.sqlserver.jdbc.SQLServerDriver

jdbc.url:jdbc:sqlserver://127.0.0.1:1444;databaseName=fax;selectMethod=cursor;

参考资料: http://www.jacken.com.cn/Database/MSSQL/

a5202003
2009-08-27 · TA获得超过2249个赞
知道大有可为答主
回答量:1885
采纳率:75%
帮助的人:593万
展开全部
可以明确的告诉楼主
一条sql语句不能更新两个表。
如果写update t1,t2 set t1.id=1,t2.id=1会出现语法错误
而你要更新的字段“申请状态”恰好在两个表里都有
因此只能是两条。

update a set 申请状态=2 from b where a.申请单号=b.申请单号 and b.申请身份证号=1
update b set 申请状态=2 where 申请身份证号=1
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
csuxp2008
2009-08-27 · TA获得超过6485个赞
知道大有可为答主
回答量:4704
采纳率:50%
帮助的人:2469万
展开全部
需要两条sql语句

update b
set b.申请状态=2
where b.申请身份证号=1;

update a
set a.申请状态=2
where a.申请单号=(select b.申请单号 from b where b.申请身份证号=1)
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
如是我之闻
2009-08-27 · TA获得超过1237个赞
知道小有建树答主
回答量:1207
采纳率:57%
帮助的人:823万
展开全部
update (select * from FROM 表A t, 表B s WHERE t.申请单号 = s.申请单号) a set a.申请状态 = 2 where a.身份证号=‘1’

这样你试试吧,不过你这两张表存在冗余,因而加大了难度。其实一个表中可以完全不要申请状态
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
柴关贵深0m
2009-08-27 · TA获得超过1142个赞
知道小有建树答主
回答量:1270
采纳率:0%
帮助的人:0
展开全部
update a set 申请状态=2 where 申请状态 in (select 申请状态 from b where 申请身份证号=1);
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式