mybatis 单一参数时的动态语句

多参数时,可以传对象或封装成map

  1. public void getBookList(String publisher,String author){
  2. Map<String,Object> maps = new HashMap<String, Object>();
  3. maps.put("publisher", publisher);
  4. maps.put("author", author);
  5. this.getListByEntity("getBookList",maps);
  6. }


  1. <select id="getBookList"  resultType="Book">
  2. SELECT * FROM bookinfo
  3. <where>
  4. <if test="publisher != null">
  5. publisher = #{publisher}
  6. </if>
  7. <if test="author != null">
  8. AND author = #{author}
  9. </if>
  10. </where>
  11. </select>

如上写法,是没有问题的,但是当情况变得简单的时候,比如只根据作者查询图书列表的时候,当然我们可以采用和上面相同的处理方法,在方法中将参数封装到map中去。但是当我们直接使用String作为参数来查询时,就需要注意一个问题:

  1. public void getBookList(String author){
  2. this.getListByEntity("getBookListByAuthor",author);
  3. }


单一参数时,这么写会报错

  1. <select id="getBookListByAuthor" parameterType="java.lang.String" resultType="Book">
  2. SELECT * FROM bookinfo
  3. <where>
  4. <if test="author != null">
  5. author = #{author}
  6. </if>
  7. </where>
  8. </select>

看似没有问题,当我们运行的时候,报异常了,原因是当我们的参数为String时,在sql语句中#{author} 会去我们传进来的参数调getAuthor()方法获取参数,很明显,String没有对应的方法,所以报错了,那我们这里要如何引用author对象呢,需要采用下面的写法:

如下写法正解

  1. <select id="getBookListByAuthor" parameterType="java.lang.String" resultType="Book">
  2. SELECT * FROM bookinfo
  3. <where>
  4. <if test="_parameter != null">
  5. AND author = #{author}
  6. </if>
  7. </where>
  8. </select>

结论:当mybatis传参为单个参数时,在sql语句中需要使用_parameter 来引用这个参数

时间: 2024-10-12 02:28:46

mybatis 单一参数时的动态语句的相关文章

MyBatis学习 之 四、动态SQL语句

有些时候,sql语句where条件中,需要一些安全判断,例如按某一条件查询时如果传入的参数是空,此时查询出的结果很可能是空的,也许我们需要参数为空时,是查出全部的信息.使用Oracle的序列.mysql的函数生成Id.这时我们可以使用动态sql. 下文均采用mysql语法和函数(例如字符串链接函数CONCAT). 3.1 selectKey 标签 在insert语句中,在Oracle经常使用序列.在MySQL中使用函数来自动生成插入表的主键,而且需要方法能返回这个生成主键.使用myBatis的s

MyBatis学习 之 三、动态SQL语句

有些时候,sql语句where条件中,需要一些安全判断,例如按某一条件查询时如果传入的参数是空,此时查询出的结果很可能是空的,也许我们需要参数为空时,是查出全部的信息.使用Oracle的序列.mysql的函数生成Id.这时我们可以使用动态sql. 下文均采用mysql语法和函数(例如字符串链接函数CONCAT). 3.1 selectKey 标签 在insert语句中,在Oracle经常使用序列.在MySQL中使用函数来自动生成插入表的主键,而且需要方法能返回这个生成主键.使用myBatis的s

Mybatis:在sqlBuilder中动态的生成sql语句

最近项目当中使用到MyBatis 动态语句生成的功能,我使用的是sqlBuilder,话不多说,直接上代码,StockMarketProvider.java: public String selectByStockIdSql(){ BEGIN(); SELECT("*"); FROM(TABLE_NAME); WHERE("stock_id = #{0}"); return SQL(); } public String updateByStockIdSql(){ B

MyBatis传入参数与parameterType

Mybatis的Mapper文件中的select.insert.update.delete元素中有一个parameterType属性,用于对应的mapper接口方法接受的参数类型. 可以接受的参数类型有基本类型和复杂类型. mapper接口方法一般接受一个参数,可以通过使用@Param注释将多个参数绑定到一个map做为输入参数. 简单数据类型 mapper接口方法: User selectByPrimaryKey(Integer id); sql映射: <select id="select

mybatis(一) mapper动态代理

因为dao开发,会每次创建实体类对象,会传入id等固定查询值,存在硬编码问题,所以采用mapper动态代理(不用创建实体类对象,只需要接口,由mapper自动生成) 与之前mybatis(一)步骤一样,但是需要将mapper.xml文件作出修改: namespace:必须是接口类的全路径 (<mapper namespace="">) id:必须是接口的方法名(<select id=""/>) parameterType:必须是接口方法里面的

mybatis 的参数处理

1.接口中传递参数不同数量时的情况处理: a.单个参数的情况: mybatis不会做特殊处理,可以使用 #{参数名/任意名}:取出参数值.(可以看到上面的输出结果没有任何问题.) b.多个参数的情况: 如果按照上面的方式指定,即如下图所示,会出异常.(这样截图太多,不写地太过详细) 注:可以看到,异常报错提示中,只能够以索引值或者 param1,param2,... 的方式来指定. c.命名参数的形式指定:在指定的方法中添加 @Param("指定参数名") 注解即可.(可以看到下面的输

动态语句SQL语句写法

/****************************************************************************************************************************************************** 动态语句语法:exec/sp_executesql语法 整理人:中国风(Roy) 日期:2008.06.06 *******************************************

动态游标(例如表名作为参数)以及动态SQL分析

表名作为参数的动态游标 DECLARE v_table_name VARCHAR2(30) := 'CUX_MES_WIP_BARCODE_MAP'; --l_rec SYS_REFCURSOR; TYPE t_data IS TABLE OF VARCHAR2(30) INDEX BY BINARY_INTEGER; TYPE t_cur IS REF CURSOR; l_data t_data; l_rec t_cur; l_cur VARCHAR2(4000); v_fm_barcode

【转】Oracle 执行动态语句

1.静态SQLSQL与动态SQL Oracle编译PL/SQL程序块分为两个种:其一为前期联编(early binding),即SQL语句在程序编译期间就已经确定,大多数的编译情况属于这种类型:另外一种是后期联编(late binding),即SQL语句只有在运行阶段才能建立,例如当查询条件为用户输入时,那么Oracle的SQL引擎就无法在编译期对该程序语句进行确定,只能在用户输入一定的查询条件后才能提交给SQL引擎进行处理.通常,静态SQL采用前一种编译方式,而动态SQL采用后一种编译方式.