SQL一条语句更新两个表!
a表有以下字段申请单号(主键)、申请日期、申请状态B表中有以下字段:申请单号(外键)、申请人姓名、申请身份证号、申请状态。现在我想更新身份证号为1的人的申请状态都为2,可...
a表有以下字段 申请单号(主键)、申请日期、申请状态
B表中有以下字段:申请单号(外键)、申请人姓名、申请身份证号、申请状态。
现在我想更新身份证号为1的人的申请状态都为2,可以用一条语句实现吗?
这表只是我假设的而已~~我要的SQL语句数据库的结构另论
2楼给的应该不对吧,我要的是同时更改两个表的申请状态为2!
现在只是改a表里的吧?
3楼给的好复杂啊,我看不是很懂,但是我要的只是SQL语句~
很感谢各位,只是只能采纳一个答案!~
不好意思了!
还是谢谢! 展开
B表中有以下字段:申请单号(外键)、申请人姓名、申请身份证号、申请状态。
现在我想更新身份证号为1的人的申请状态都为2,可以用一条语句实现吗?
这表只是我假设的而已~~我要的SQL语句数据库的结构另论
2楼给的应该不对吧,我要的是同时更改两个表的申请状态为2!
现在只是改a表里的吧?
3楼给的好复杂啊,我看不是很懂,但是我要的只是SQL语句~
很感谢各位,只是只能采纳一个答案!~
不好意思了!
还是谢谢! 展开
6个回答
展开全部
首先注意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;
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/
展开全部
可以明确的告诉楼主
一条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
一条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
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
需要两条sql语句
update b
set b.申请状态=2
where b.申请身份证号=1;
update a
set a.申请状态=2
where a.申请单号=(select b.申请单号 from b where b.申请身份证号=1)
update b
set b.申请状态=2
where b.申请身份证号=1;
update a
set a.申请状态=2
where a.申请单号=(select b.申请单号 from b where b.申请身份证号=1)
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
update (select * from FROM 表A t, 表B s WHERE t.申请单号 = s.申请单号) a set a.申请状态 = 2 where a.身份证号=‘1’
这样你试试吧,不过你这两张表存在冗余,因而加大了难度。其实一个表中可以完全不要申请状态
这样你试试吧,不过你这两张表存在冗余,因而加大了难度。其实一个表中可以完全不要申请状态
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
update a set 申请状态=2 where 申请状态 in (select 申请状态 from b where 申请身份证号=1);
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询