有没有hibernate查看不带问号的sql 语句的包

今天调试一个多对多关系,老是报“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,就搞定了。有空的朋友不妨试试。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值