其实这个不是动态的,不过要写就把CRUD全写一边了,因为IBATIS很简单,就不放
JAVA代码,直接上XML
<delete id="delete_role_id" parameterClass="java.util.Map">
delete myivr_trole where ROLEID in
<iterate open="(" close=")" conjunction="," property="ids">
#ids[]#
</iterate>
</delete>
这样的话,你在DAO中写
/**
* 根据角色ID删除角色
* @param ids 角色ID
* @return int 影响行数:如果delete N条就返回N
*/
public Integer deleteRoleById(Integer... ids) {
Map<String,Object> map = new HashMap<String, Object>();
map.put("ids", ids);
return (Integer)getSqlMapClientTemplate().delete("role.delete_role_id", map);
}
用Map传参数那么,iterate里面的property属性一定要和Map中的key相同,但是你还可以有更方便的选择,如下:
<delete id="delete_user_id" parameterClass="java.util.List">
delete myivr_tuser where USERID in
<iterate open="(" close=")" conjunction=",">
#ids[]#
</iterate>
</delete>
再看DAO代码
public Integer deleteUserById(Integer... ids) {
return super.getSqlMapClientTemplate().delete("user.delete_user_id", Arrays.asList(ids));
}
方便吧,不需要自己构建一个Map里,而且XML里面的#ids[]#名称可以顺便写的,呵呵
不过需要注意一下,这里的parameterClass一定要是java.util.List不能是java.util.ArrayList,因为ibatis内部用了反射机制,他不认Arrays.asList,比较class的出错,但是写List就可以了。
分享到:
相关推荐
Ibatis API 的一个重要特点是动态SQL,它允许在XML配置文件或Mapper接口注解中编写条件语句,使得SQL的生成更加灵活,适应复杂的业务场景。 在实际开发中,Ibatis API 可以与Spring框架集成,通过Spring的`...
iBatis,现已被MyBatis取代,是Java中的一个持久层框架,它简化了数据库操作,通过XML或注解的方式将SQL与Java代码绑定,避免了传统的JDBC代码编写工作,提高了开发效率和代码的可读性。它处理结果映射,事务管理,...
在 iBATIS 中,可以使用 OGNL 表达式或动态 SQL 来实现对字段进行 LIKE 查询,例如 `%${param}%`,其中 `${param}` 是传入的参数。 这些操作都是基于 SQL Map 文件,这是一个 XML 文件,其中包含了 SQL 语句及其与 ...
- **动态SQL**:掌握如何使用iBATIS的动态SQL功能,实现条件语句和循环结构的动态构建。 ### iBATIS在现实世界的应用 - **性能优化与缓存**:了解如何利用iBATIS的缓存机制来提高应用性能,减少数据库访问次数。 -...
6. **Dynamic SQL**:允许在XML映射文件中进行条件判断,动态生成SQL语句,提高了SQL的灵活性和复用性。 7. **Transactions**:SQL Maps支持声明式和编程式的事务管理,确保数据的一致性和完整性。 通过使用iBATIS...
iBATIS 支持动态 SQL,即根据运行时的条件动态构建 SQL 语句。这包括: - **二进制条件元素**:例如 `<if>` 和 `<choose>` 等元素,用于构建复杂的条件逻辑。 - **简单动态 SQL 元素**:如 `<where>` 和 `<set>` 等...
Ibatis提供强大的动态SQL功能,允许在XML映射文件中进行条件判断、循环等复杂操作,如`<if>`, `<choose>`, `<when>`, `<otherwise>`, `<where>`, `<foreach>`等标签。 五、Mapper接口与注解 1. Mapper接口:定义...
这些SQL语句主要用于Oracle数据库中,涉及到了删除、插入以及查询等基本操作,并且在ibatis框架中实现了参数化处理。 ### 一、删除操作 首先我们来看第一条SQL语句: ```xml <delete id=...
5. **动态SQL**:探索 iBATIS 如何通过`<if>`、`<choose>`、`<when>`、`<otherwise>`等标签实现条件判断和动态SQL生成。 6. **事务管理**:理解 iBATIS 的事务控制机制,包括自动和手动提交、回滚和隔离级别设置。 ...
1. 动态SQL:Ibatis-SqlMap支持在XML映射文件中编写动态SQL,使得SQL生成更加灵活。 2. 缓存机制:提供了一级缓存和二级缓存,能够提高数据访问效率。 3. 映射文件和Java代码分离:通过XML配置文件,将SQL逻辑和业务...
在iBATIS中,当输入参数为单个值时,如示例中的`long`类型,可以使用`<delete>`标签结合`#value#`占位符来构建SQL语句。这里的`#value#`会被实际的参数值替换,从而执行具体的数据库删除操作。这种简单的参数绑定...
本文将详细介绍ibatis中的SQL语句编写方法,主要包括查询、插入、更新和删除等基本操作,并通过一个具体的例子来加深理解。 #### 二、ibatis简介 Ibatis是一个基于Java的持久层框架,它支持定制化SQL、存储过程...
在业务逻辑中,我们通常会通过Mapper接口与数据库进行交互,这些接口的定义与XML配置文件中的SQL语句相对应,这样就实现了SQL语句的动态绑定。 1. SqlSessionFactoryBuilder:这个类用于构建SqlSessionFactory。...
在实际应用中,iBATIS的一个显著优点是它可以灵活地处理复杂的SQL,而不像ORM框架那样将SQL完全抽象化。这使得开发者可以充分利用数据库的特性,提高查询效率。然而,这也意味着开发者需要对SQL有较深入的理解。 总...
此外,该工具可能还包含了对复杂的查询条件的支持,比如模糊搜索、分页查询等,这些在生成的SQL中会以动态SQL的形式出现,使得代码更加简洁和易于维护。对于大型项目而言,这种自动化生成的功能能够显著减少编码时间...
iBATIS 的动态SQL功能允许开发者在XML配置文件中编写条件化的SQL语句,可以根据实际参数来决定SQL的执行部分。这大大增加了SQL的灵活性,避免了因为硬编码而导致的重复SQL语句。 **事务管理** iBATIS 提供了事务...
- **参数传递**:在SQL映射文件中,可以通过参数传递机制将Java对象的属性值映射到SQL语句中,使得动态SQL变得简单易用。 #### 六、总结 iBATIS作为一种灵活的ORM框架,特别适合那些需要在不修改现有数据库结构的...
4. 动态SQL:iBatis的一大亮点是其动态SQL功能,允许在XML映射文件中根据条件构建SQL语句。例如,if、choose、when、otherwise、where等标签,极大地提高了SQL的可维护性和灵活性。 5. ResultMap:ResultMap用于...
在Ibatis中,`sql-map`和`sql-map-config`是两个重要的XML配置文件,它们使用DTD(Document Type Definition)来定义其结构和规则。 DTD是XML文档类型定义,它定义了XML文档的合法构建块,包括元素、属性、实体等,...
基础语义中,Ibatis提供了多种执行SQL的方式,如select、insert、update和delete等标签,用于执行CRUD操作。例如,用于查询User对象,其中id是SQL映射的唯一标识,resultType指定返回的结果类型。 ...