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

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 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 2008-12-02 16:58
    关注

    可以直接写在SqlMap中呀?

    有问题么? :o

    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥20 arcgis制做交通拥堵时变图
  • ¥15 AD20 PCB板步线 这个要怎么步啊
  • ¥50 关于《奇迹世界》1.5版本,数据修改
  • ¥15 请问这个问题如何解决(关键词-File)
  • ¥50 visual studio 2022和EasyX图形化界面
  • ¥15 找一下报错原因,纠正一下
  • ¥50 Cox回归模型Nomogram图制作报错
  • ¥20 SQL如何查询多级用户的数据
  • ¥15 给车牌识别代码加一个识别轮廓长宽比的代码
  • ¥30 商品价格预测的transformer模型优化