当数组遇到mybatis in 的时候
来源:互联网 发布:淘宝客贷款申请条件 编辑:程序博客网 时间:2024/06/06 00:29
我想实现 “多个id 传入sql 语句“的操作。
1、我试着将数组 stringUtils.join(数组,","); //数组转string 并以逗号分隔
没成功。因为传到sql 里是“123,234,435” ,而我们需要的是“123”,“234”,“345” 这样格式。
2、oracle split string to table
select * from table1 where id in (select * from table(str2table(#{ids},‘,’)));
而 str2table可以这样写:
CREATE OR REPLACE TYPE TY_OBJECT AS OBJECT(COL_NAME VARCHAR2(200));
/
CREATE OR REPLACE TYPE TY_TABLE AS TABLE OF TY_OBJECT;
/
CREATE OR REPLACE FUNCTION STR2TABLE(V_STR IN VARCHAR2,
V_DELIMITER IN VARCHAR2)
--此函数的目的是将以特定字符分隔的字符串转换为游标形式,以例遍历此游标
RETURN TY_TABLE AS
V_TY_TABLE TY_TABLE;
BEGIN
SELECT TY_OBJECT(REGEXP_SUBSTR(V_STR,
'[^' || V_DELIMITER || ']+',
1,
LEVEL,
'i'))
BULK COLLECT
INTO V_TY_TABLE
FROM DUAL
CONNECT BY LEVEL <=
LENGTH(V_STR) -
LENGTH(REGEXP_REPLACE(V_STR, '' || V_DELIMITER || '', '')) + 1;
RETURN V_TY_TABLE;
END;
摘自:http://blog.csdn.net/e_wsq/article/details/52381846
这样就能获得“123”,“234”,“345”的格式
3、还可以用mybatis 自带的 foreach 方法
1. 当查询的参数只有一个时
findByIds(List<Long> ids)
1.a 如果参数的类型是List, 则在使用时,collection属性要必须指定为 list
<select id="findByIdsMap" resultMap="BaseResultMap"> Select <include refid="Base_Column_List" /> from jria where ID in <foreach item="item" index="index" collection="list" open="(" separator="," close=")"> #{item} </foreach> </select>
findByIds(Long[] ids)
1.b 如果参数的类型是Array,则在使用时,collection属性要必须指定为 array
<select id="findByIdsMap" resultMap="BaseResultMap"> select <include refid="Base_Column_List" /> from jria where ID in <foreach item="item" index="index" collection="array" open="(" separator="," close=")"> #{item} </foreach> </select>
2. 当查询的参数有多个时,例如 findByIds(String name, Long[] ids)
这种情况需要特别注意,在传参数时,一定要改用Map方式, 这样在collection属性可以指定名称
下面是一个示例
Map<String, Object> params = new HashMap<String, Object>(2); params.put("name", name); params.put("ids", ids); mapper.findByIdsMap(params); <select id="findByIdsMap" resultMap="BaseResultMap"> select <include refid="Base_Column_List" /> from jria where ID in <foreach item="item" index="index" collection="ids" open="(" separator="," close=")"> #{item} </foreach> </select>
摘自:http://blog.csdn.net/jarniyy/article/details/51169242
- 当数组遇到mybatis in 的时候
- 噩梦!!! 当Oracle遇到优化大师的时候~
- 当你遇到internal的时候
- 当NANSHAN遇到SouSouSMap脚本的时候
- 当程序遇到Crash的时候
- 当sqserver的N遇到mybatis
- 当自己的Ubuntu遇到卡死的时候
- 当单例模式遇到多线程并发的时候
- 当我们遇到问题的时候改如何解决
- 当不确定输入数组为多少个的时候
- 当数组是一个对象的时候转list
- Yii Html::a 当参数是数组的时候
- 当遇到error: stray '\241' in program错误的解决方法
- 当遇到error: stray '\241' in program错误的解决方法
- 当罗密欧遇到朱丽叶... ...当指针遇到数组
- 当页面加载的时候就捕获其keydown事件所遇到的问题以及解决办法。
- 当传入数据只有一个值的时候mybatis会报错
- 当你遇到"modifying layer that is being finalized"的时候怎么办?
- 我是一只IT小小鸟
- java设计模式简单介绍
- 配置Hadoop伪分布式模式并运行WordCount示例操作实例演示步骤
- cadence学习(一)封装制作
- Python 文件I/O和File方法
- 当数组遇到mybatis in 的时候
- jQuery源码分析(版本1.6.1)
- nigx.conf
- 7个有益的编程习惯
- 关于三缓存机制的使用
- Java Regular (二) 去 掉 排 除 词
- java socket写一个小型聊天室
- c++ float 转换到string
- Java中的基本类型和引用类型变量的区别