`
zpanda
  • 浏览: 5225 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Mybatis多参数查询映射

阅读更多
规则
非@Param注解参数时可使用
#{参数位置[0..n-1]}
或者
#{param[1..n]}
如果参数类型是自定义对象(bean)时,只需加上.对象属性即可
#{参数位置[0..n-1].对象属性}
#{param[1..n].对象属性}
特别的,如果非注解参数只有一个时,可使用
#{任意字符}
来访问参数
@Param的作用是设置参数别名。设置后的参数只能通过
#{注解别名}
或者
#{param[1..n]}    
如果参数类型是自定义对象(bean)时,只需加上.对象属性即可
  #{注解别名.属性}
  #{param[1..n].属性}
来访问参数
示例
为了明确上述规则,我们的示例具体细分了各种情况进行展示。
非注解型
一个参数
[java] view plaincopyprint?
<span style="font-weight: normal;"><span style="font-family:Microsoft YaHei;font-size:14px;">User getUserById(int id); 
 
select * from <TABLE> where id = #{id} 
// or 
select * from <TABLE> where id = #{abdc} 
// or 
select * from <TABLE> where id = #{param1} 
 
User getUser(User user); // user.getName user.getAge  
 
select * from <TABLE> where name = #{name} and age = #{age}</span></span> 


多个参数
[java] view plaincopyprint?
<span style="font-family:Microsoft YaHei;font-size:14px;">User getUser(String name, int age);   
 
select * from <TABLE> where name = #{0} and age = #{1}   
// or   
select * from <TABLE> where name = #{param1} and age = #{param2}   
 
User getUser(User usr, int flag);   
 
select * from <TABLE> where name = #{0.name} and age = {0.age} and flag = #{1}   
// or   
select * from <TABLE> where name = #{param1.name} and age = {param1.age} and flag = #{param2}</span> 


注解型
一个参数
[java] view plaincopyprint?
<span style="font-family:Microsoft YaHei;font-size:14px;">User getUserById(@Param(value="keyId") int id);   
 
select * from <TABEL> where id = #{keyId}   
// or   
select * from <TABLE> where id = #{param1}   
 
User getUser(@Param(value="user") User user); // user.getName user.getAge   
 
select * from <TABLE> where name = #{user.name} and age = #{user.age}   
// or   
select * from <TABLE> where name = #{param1.name} and age = #{param1.age}</span> 


多个参数
[java] view plaincopyprint?
<span style="font-family:Microsoft YaHei;font-size:14px;">User getUser(@Param(value="xm") String name, @Param(value="nl") int age);   
 
select * from <TABLE> where name = #{xm} and age = #{nl}   
// or   
select * from <TABLE> where name = #{param1} and age = #{param2}   
// or   
select * from <TABLE> where name = #{xm} and age = #{param2}   
 
User getUser(@Param(value="usr") User user, @Param(value="tag") int flag);  
 
select * from <TABLE> where name = #{usr.name} and age = #{usr.age} and flag = #{tag}   
// or   
select * from <TABLE> where name = #{param1.name} and age = #{param1.age} and flag = #{param2}   
// or   
select * from <TABLE> where name = #{usr.name} and age = #{param1.age} and flag = #{param2}</span> 


非注解和注解型混合型
当采用部分参数使用@Param注解时,参数注释为将以上两种情况结合起来即可.
[java] view plaincopyprint?
<span style="font-family:Microsoft YaHei;font-size:14px;">User getUser(String name, @Param(value="nl") age, int gendar);   
 
// 对于age的访问不能是 #{1} 只能是 #{param2} | #{nl}   
select * from <TABLE> where name = #{0} and age = #{nl} and gendar = #{param3)</span> 

框架主要映射处理代码
参数的获取
[java] view plaincopyprint?
<span style="font-family:Microsoft YaHei;font-size:14px;">org.apache.ibatis.binding.MapperMethod 
private Object getParam(Object[] args) {   
    final int paramCount = paramPositions.size();   
    // 无参数   
    if (args == null || paramCount == 0) {   
        return null;   
    // 无注解并参数个数为1   
    } else if (!hasNamedParameters && paramCount == 1) {   
        return args[paramPositions.get(0)];   
    } else {   
        Map<String, Object> param = new MapperParamMap<Object>();   
        for (int i = 0; i < paramCount; i++) {   
            param.put(paramNames.get(i), args[paramPositions.get(i)]);   
    }   
    // issue #71, add param names as param1, param2...but ensure backward compatibility   
    // 这就是 #{param[1..n]} 的来源   
    for (int i = 0; i < paramCount; i++) {   
        String genericParamName = "param" + String.valueOf(i + 1);   
        if (!param.containsKey(genericParamName)) {   
            param.put(genericParamName, args[paramPositions.get(i)]);   
        }   
    }   
    return param;   
    }   
}</span> 


SQL预编译参数设置
[java] view plaincopyprint?
<span style="font-family:Microsoft YaHei;font-size:14px;">org.apache.ibatis.executor.parameter.DefaultParameterHandler 
public void setParameters(PreparedStatement ps) throws SQLException {   
    ErrorContext.instance().activity("setting parameters").object(mappedStatement.getParameterMap().getId());   
    List<ParameterMapping> parameterMappings = boundSql.getParameterMappings();   
    if (parameterMappings != null) {   
        MetaObject metaObject = parameterObject == null ? null : configuration.newMetaObject(parameterObject);   
        for (int i = 0; i < parameterMappings.size(); i++) {   
            ParameterMapping parameterMapping = parameterMappings.get(i);   
            if (parameterMapping.getMode() != ParameterMode.OUT) {   
                Object value;   
                String propertyName = parameterMapping.getProperty();   
                PropertyTokenizer prop = new PropertyTokenizer(propertyName);   
                if (parameterObject == null) {   
                    value = null;   
                } else if (typeHandlerRegistry.hasTypeHandler(parameterObject.getClass())) {   
                    value = parameterObject;   
                } else if (boundSql.hasAdditionalParameter(propertyName)) {   
                    value = boundSql.getAdditionalParameter(propertyName);   
                } else if (propertyName.startsWith(ForEachSqlNode.ITEM_PREFIX)   
          && boundSql.hasAdditionalParameter(prop.getName())) {   
                    value = boundSql.getAdditionalParameter(prop.getName());   
                    if (value != null) {   
                        value = configuration.newMetaObject(value).getValue(propertyName.substring(prop.getName().length()));   
                    }   
            } else {   
                value = metaObject == null ? null : metaObject.getValue(propertyName);   
            }   
            TypeHandler typeHandler = parameterMapping.getTypeHandler();   
            if (typeHandler == null) {   
                throw new ExecutorException("There was no TypeHandler found for parameter " + propertyName + " of statement " + mappedStatement.getId());   
            }   
            JdbcType jdbcType = parameterMapping.getJdbcType();   
            if (value == null && jdbcType == null) jdbcType = configuration.getJdbcTypeForNull();   
                typeHandler.setParameter(ps, i + 1, value, jdbcType);   
            }   
        }   
    }   
分享到:
评论

相关推荐

    Mybatis-03 SQL映射文件

    详解MyBatis框架中SQL映射文件的具体配置,包括实现增删改查操作、根据主键生成方式获取主键值、针对单个参数、多个参数和命名参数的处理与参数值获取以及select标签中resultMap的详解

    springmybatis

    MyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索。MyBatis使用简单的XML或注解用于配置和原始映射,将接口和Java的POJOs(Plan ...

    mybatis配置数据源、别名,映射器,执行数据库的查询, 带一个参数及多个参数的查询,新增等

    mybatis配置数据源、别名,映射器,执行数据库的查询, 带一个参数及多个参数的查询,新增等 包含学习视频及项目源码, 包含授课笔记

    解析Mybatis连续传递多个参数的方法

    MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架,这篇文章主要介绍了Mybatis连续传递多个参数的方法,需要的朋友可以参考下

    mybatis中文版教程

    MyBatis 是支持普通 SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis 消除  了几乎所有的 JDBC 代码和参数的手工设置以及结果集的检索。MyBatis 使用简单的 XML  或注解用于配置和原始映射,将接口和 Java ...

    IDEA中MyBatis逆向工程.txt

    MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的...

    mybatis学习笔记

    6.3.7 Mybatis Cache参数 64 6.3.8 mybatis整合ehcache 64 6.3.9 应用场景 67 6.3.10 局限性 67 7 与spring整合 68 7.1 mybatis与spring整合jar 68 7.2 Mybatis配置文件 68 7.3 Spring配置文件: 69 7.4 Mapper编写...

    mybatis-tutorial:mybatis 入门教程

    MyBatis 教程MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。...文章列表:一对一和一对多的延迟加载多对多的实现分页查询把SQL写在注解中自动生成Mapper代码和映射XML

    Spring+MVC+Mybatis 书城项目

    MyBatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集。MyBatis可以使用简单的XML或注解来配置和映射原生信息,将接口和Java的POJOs (Plain Old Java Objects, 普通的Java对象)映射为数据库中的记录。 项目...

    MyBatis项目:ALL

    maven02:获取参数值两种方式、查询结果单个或多条接收、模糊查询等特殊功能 maven03:两表多对一/一对多ResultMap解决字段与属性映射、动态SQL标签、缓存 MyBatis_MBG:逆向工程(奢华尊享版)(由数据库逆向自动...

    基于框架的Web开发-映射详解.doc

    为了避免使用多句resource语句引入多个映射xml文件,这里使用package将mappers包引入,会将这个包下面的映射文件一起引入 为了避免使用多句resource语句引入多个映射xml文件,这里使用package将mappers包引入,会将...

    深入浅出MyBatis框架

    MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的...

    mybatis-cn:mybatis二进制的中文注释以及mybatis的使用和二进制解析

    :连接中需要引入多个参数,试一下注解模式吧:来试试高级映射功能:一对多的高级映射:一级缓存,二级缓存,提升性能的同时,也注意它的限制 :我再也不要在代码中拆分语句了!!来用mybatis动态SQL爽一爽吧 :sql...

    MyBatis 逆向工程

    MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录...

    SSM框架的学习与应用-Java EE企业级应用开发学习记录(第三天)Mybatis的深入学习(动态sql的操作)

    通过元素示例演示了根据输入参数动态构建查询条件。 通过元素示例演示了多条件选择动态查询。 通过、元素示例演示了自动处理关键字的动态查询。 通过元素示例演示了动态更新指定字段。 通过元素示例演示了对数组列表...

    1000道 互联网Java架构师面试题.pdf和JAVA核心知识整理.zip

    18、为什么说 Mybatis 是半自动 ORM 映射工具?它与全自动的区别在哪里? 19、 一对一、一对多的关联查询 ? 20、MyBatis 实现一对一有几种方式?具体怎么操作的? 21、MyBatis 实现一对多有几种方式,怎么操作的?...

    MyBatis入门视频课程

    本课程以通俗易懂的方式讲解MyBatis技术,课程内容包括:...7.多参数查询 8.动态SQL 9.多表关系映射 10.代码生成器mybatis-generator 11.分页插件PageHelper 教学全程采用笔记+代码案例的形式讲解,通俗易懂!!!

    mybatis框架 快速入门 基础+提高 实战视频教程

    mybatis通过xml或注解的方式将要执行的各种statement配置起来,并通过java对象和statement中sql的动态参数进行映射生成最终执行的sql语句,最后由mybatis框架执行sql并将结果映射为java对象并返回。采用ORM思想解决...

    MyBatis实战教程

    本课程适合有JAVA和数据库基础的人员。 本课程使用Eclipse和IntelliJ IDEA两种开发工具,详细的讲解了MyBatis的各种语法,并且讲解了MyBatis逆向工程和MyBatis两种常用的插件:... 12.MyBatis处理多个参数的问题? ? ?

    spring-dubbo-service:微服务spring dubbo项目:dubbo rpc;德鲁伊数据源连接池; mybatis配置集成,多数据源; jmx监控MBean;定时任务; aop; ftp;测试;指标监控;参数验证;跨域处理; shiro权限控制; consul服务注册,发现; redis分布式锁; SPI服务机制; cat监控; netty服务代理; websocket; disconf; mongodb集成;休息; docker; fescar

    spring-dubbo-service微服务一,服务模块1,服务器配置:servlet,侦听器,拦截器,过滤器,aop,定时任务mybatis配置集成,多数据源;级联查询一对一对一对多注解配置及xml配置方式;分页处理:传递Page参数或继承...

Global site tag (gtag.js) - Google Analytics