您的位置:首页 > 其它

新发布缺陷管理系统(DMC)1.04 版本

2009-01-04 20:31 651 查看
今天调试一个多对多关系,老是报“a foreign key constraint fails”,拷贝出sql语句运行,好好的。后来发现原来是key写反了:
<set name="resources" table="t_role_res" cascade="save-update">
<key column="[color=red]resource_id[/color]"/>
<many-to-many class="com.ces.auth.pojo.Resource" column="[color=red]role_id[/color]"/>
</set>

于是想到,是不是能有个包让俺们调试起来方便一些呢,从技术角度讲,这是有可能的,无非就是把sql中的问号替换一下。于是找来preparestatement的操作,发现这个想法可行。
1条记录:
PreparedStatement pstmt = con.prepareStatement("UPDATE EMPLOYEES
SET SALARY = ? WHERE ID = ?");
pstmt.setBigDecimal(1, 153833.00)
pstmt.setInt(2, 110592)
多条记录:
PreparedStatement pstmt = conn.prepareStatement(sql)
pstmt.setXXX();
...
pstmt.addBatch();
pstmt.setXXX();
...
pstmt.addBatch();
...
pstmt.executeBatch();


所以用AOP切一下PreparedStatement 的setXXX方法,然后再拼一个sql,就搞定了。有空的朋友不妨试试。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: