vdgame
2008-12-02 16:35 浏览 501
已采纳

ibatis中SQL子查询的使用

对于下面这样的包含子查询的语句,在ibatis中怎么处理?只能拼SQL了?
select * from agent where province_code in(select province_code from operator_biz_province where operator_id =%d)
[b]问题补充:[/b]
province_code in(select province_code from operator_biz_province where operator_id =%d) 是变化的,比如
operator_id in(....)
[b]问题补充:[/b]
我现在是做成:
select * from agent $conditions$
conditions的值是自己拼SQL语句,再通过map传到ibatis中。
想知道有没有更好的方法

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享
  • 邀请回答

2条回答 默认 最新

  • 已采纳
    lggegegmail lggegegmail 2008-12-02 17:08

    这样的, 你可以传operator_id的list进来,
    iBATIS是有一个iterator的, 可以循环list.

    我的代码的参数是传入A对象,
    [code="java"]class A {
    List status;
    }

            <isNotNull property="status">
                <isNotEmpty prepend="AND " property="status">
                    <iterate property="status" open=" STATUS IN (" close=")" conjunction=", ">
                        #status[]#
                    </iterate>
                </isNotEmpty>
            </isNotNull>
    

    [/code]

    点赞 评论 复制链接分享
  • lggegegmail lggegegmail 2008-12-02 16:58

    可以直接写在SqlMap中呀?

    有问题么? :o

    点赞 评论 复制链接分享

相关推荐