今天调试一个多对多关系,老是报“a foreign key constraint fails”,拷贝出sql语句运行,好好的。后来发现原来是key写反了:
于是想到,是不是能有个包让俺们调试起来方便一些呢,从技术角度讲,这是有可能的,无非就是把sql中的问号替换一下。于是找来preparestatement的操作,发现这个想法可行。
所以用AOP切一下PreparedStatement 的setXXX方法,然后再拼一个sql,就搞定了。有空的朋友不妨试试。
<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,就搞定了。有空的朋友不妨试试。