`

myibatis3 动态sql 查询

 
阅读更多

1.mysql  配置sql 文件

<!-- 动态sql查询 -->
 <select id="muti_list" parameterType="java.util.List" resultMap="id_Resources">
  select * from sys_resource s where s.id in
       <foreach collection="list" index="index" item="item" open="(" separator="," close=")">
        #{item}
      </foreach>
 
 </select>

 

2.程序实现

@Override
 public List mutiList(List list) throws Exception {
  // TODO Auto-generated method stub
  return this.getSqlSession().selectList(sql_pre+"muti_list", list);
 }

  调用ID 为muti_list 的sql

 

3.测试方法:

 

public void deleteByIdOne(){
  ResouceDao dao  = (ResouceDao)app.getBean("resouceDao");
  try {
  //System.out.println(dao.deleteById(216l));
   List list = new ArrayList();
   list.add(218);
   list.add(217);
   list.add(219);
   List l = dao.mutiList(list);
   for(Object res:l){
    System.out.println(res);
   }
  } catch (Exception e) {
   e.printStackTrace();
  }
 }

 

 

打印sql 语句:

[boce.auth.shiro.pojo.Resources.muti_list] - ==>  Preparing: select * from sys_resource s where s.id in ( ? , ? , ? ) 
2016-05-23 16:56:12,776 DEBUG [boce.auth.shiro.pojo.Resources.muti_list] - ==> Parameters: 218(Integer), 217(Integer), 219(Integer)
2016-05-23 16:56:12,799 DEBUG [boce.auth.shiro.pojo.Resources.muti_list] - <==      Total: 3

 

 

输出结果:

Resource{id=217, name='gaojiangp', type=menu, permission='view:view', parentId=0, parentIds='0/1', available=true}
Resource{id=218, name='gaojiangp', type=menu, permission='view:view', parentId=0, parentIds='0/1', available=true}
Resource{id=219, name='渤海', type=menu, permission='update:update', parentId=1, parentIds='0/1/', available=false}

 

 

 

 

分享到:
评论

相关推荐

    mybatis之动态SQL

    MyBatis 是一款深受 Java 开发者喜爱的持久层框架,它允许开发者将 SQL 查询与 Java 代码直接关联,提供了一种灵活的方式来处理数据库交互。动态 SQL 是 MyBatis 的一大特色,它允许我们在运行时根据条件构建 SQL ...

    mybatis动态sql.zip

    mybatis动态sql,动态sql解析引擎,类似mybatis动态sql的功能。 mybatis动态sql,动态sql解析引擎,类似mybatis动态sql的功能。mybatis动态sql,动态sql解析引擎,类似mybatis动态sql的功能。mybatis动态sql,...

    mybatis 动态sql及参数传递

    在实际开发过程中,我们往往需要编写复杂的SQL语句,拼接稍有不注意就会导致错误,Mybatis给开发者提供了动态SQL,大大降低了拼接SQL导致的错误。 动态标签 if标签 if标签通常用那个胡where语句,update语句,insert...

    MyBatis动态拼接SQL

    在某些场景下,我们可能需要根据业务逻辑动态地拼接SQL语句,以实现更复杂的查询需求。这就是MyBatis动态SQL的功能所在。 动态SQL是MyBatis的一大特色,它使得我们能够在运行时根据条件构建SQL语句。MyBatis通过`...

    详解MyBatis直接执行SQL查询及数据批量插入

    在本文中,我们将深入探讨如何使用MyBatis直接执行SQL查询以及如何进行数据的批量插入。 **一、直接执行SQL查询** 在MyBatis中,你可以通过Mapper接口和XML配置文件来直接执行自定义的SQL查询。下面是一个简单的...

    Mybatis3动态SQL物理分页

    Mybatis的自带分页方法只是逻辑分页,如果数据量很大,内存会溢出, 不知道为什么开源组织不在里面实现类似Hibernate的物理分页处理方法。 在不改动Mybatis源代码的情况下实现Mybatis支持物理分页

    mybatis直接执行sql语句后续之一

    1. **动态SQL**:MyBatis的一个强大特性是其支持动态SQL,允许在XML映射文件或注解中构建SQL语句。比如,我们可以使用`&lt;if&gt;`、`&lt;choose&gt;`、`&lt;when&gt;`、`&lt;otherwise&gt;`、`&lt;where&gt;`等标签来根据条件动态地插入、删除或...

    mybatis中进行sqlserver分页

    mybatis中,sqlserver分页

    mybatis慢SQL插件

    基于mybatis的慢SQL小插件,原理是mybatis拦截器。只需要在springboot的配置文件做简单的配置,mybatis拦截器将SQL中所有参数自动做了填充。拦截器监控慢SQL并将完整的可执行的SQL语句打印在日志文件中,复制该SQL...

    MyBatis 动态 SQL 示例

    附件是MyBatis 动态 SQL 示例,MyBatis 是一个持久层框架,它允许用户在 XML 文件中编写动态 SQL 语句。MyBatis 的动态 SQL 功能非常强大,它允许开发者根据运行时的条件动态地生成 SQL 语句。这使得 MyBatis 能够...

    MyBatis 动态SQL示例

    附件是MyBatis 动态SQL示例,MyBatis 是一个持久层框架,它允许用户在 XML 文件中编写动态 SQL 语句。MyBatis 的动态 SQL 功能非常强大,它允许开发者根据运行时的条件动态地生成 SQL 语句。这使得 MyBatis 能够灵活...

    mybatis动态SQL语句

    if 、where、set、trim、choose 、foreach等在mybatis中的具体用法,有具体实例可供参考,玩转mybatis

    MyBatis动态SQL,MyBatis批量插入(Oracle数据库)[收集].pdf

    MyBatis动态SQL和批量插入的应用 MyBatis是一款功能强大且灵活的持久层框架,提供了多种方式来对数据库进行交互。其中,动态SQL是一种非常强大的特性,能够根据不同的条件生成不同的SQL语句。下面将详细介绍MyBatis...

    ssm框架\mybatis\动态sql\1.使用动态SQL完成多条件查询

    SSM框架,全称Spring+SpringMVC+MyBatis,是Java开发中常见的Web应用架构。MyBatis作为持久层框架,它允许开发者将SQL语句与Java代码分离,...在SSM框架下,MyBatis的动态SQL特性更是成为处理多条件查询的关键工具。

    MyBatis动态条件通用查询

    MyBatis动态条件通用查询是数据库操作中常见的一种需求,它允许开发者在不编写大量重复SQL语句的情况下,根据传入的参数灵活地执行查询。这个功能的核心在于利用MyBatis的动态SQL特性,结合Map数据结构来构建可变的...

    MyBatis之动态SQL.pdf

    MyBatis之动态SQL

    mybatis如何防止SQL注入

    MyBatis是一款优秀的持久层框架,它支持自定义SQL查询语句,并能与Java对象自动进行映射,极大简化了基于JDBC的数据库操作。然而,由于需要手动编写SQL语句,如果不加以防范,则可能会面临SQL注入的风险。 #### ...

    Mybatis实现动态代理,动态SQL

    "Mybatis实现动态代理,动态SQL" Mybatis框架可以通过配置的形式为DAO接口生成动态代理实现类,从而简化程序开发,提高开发效率。在实现动态代理时,需要满足以下条件:接口全命名必须和SQL映射文件中的namespace...

    《一头扎进MyBatis3》第六讲 动态SQL的实现

    在MyBatis框架中,动态SQL是其强大且灵活的功能之一,它允许我们在不编写大量重复的Java代码或SQL语句的情况下,根据条件构建复杂的查询。动态SQL的主要优点在于能够根据业务逻辑的变化自适应地调整SQL语句,提高了...

Global site tag (gtag.js) - Google Analytics