ibatis中的模糊查询

看两个最基本的语句

①select * from student where name like 'xy'
②select * from student where naem like '%xy%'

两个语句都是用了like,貌似都是模糊查询的样子。其实①实际上是一个完全匹配的查询,与用等号写成如下语句是一致的。①语句等价于select * from student where name = 'xy'。这就给在ibatis写模糊查询语句带来启示。

例子一

<dynamic prepend="where">
 <isNotNull prepend="AND" property="id">
  id = #id#
 </isNotNull>
 <isNotNull prepend="AND" property="name">
  name like #name#
 </isNotNull>
</dynamic>

该例子与①语句错误相同

 

例子二

<dynamic prepend="where">
 <isNotNull prepend="AND" property="id">
  id = #id#
 </isNotNull>
 <isNotNull prepend="AND" property="name">
  name like '%#name#%'
 </isNotNull>
</dynamic>

报错:java.sql.SQLException: Invalid argument in JDBC call: parameter index out of range: 1

 

例子三 正确

<dynamic prepend="where">
 <isNotNull prepend="AND" property="id">
  id = #id#
 </isNotNull>
 <isNotNull prepend="AND" property="name">
  name like '%$name$%'
 </isNotNull>
</dynamic>

"$"操作符相当于在SQL语句被转变为参数化语句之前,将值插入该语句

 

时间: 2024-11-17 07:31:22

ibatis中的模糊查询的相关文章

在java List中进行模糊查询的实现方法_java

比如我有下面这样一个List,里面存放的是多个Employee对象.然后我想对这个List进行按照Employee对象的名字进行模糊查询.有什么好的解决方案么? 比如我输入的查询条件为"wang",那么应该返回只包含employee1的List列表. List list = new ArrayList(); Employee employee1 = new Employee(); employee1.setName("wangqiang"); employee1.s

找出mysql中like模糊查询效率低的sql语句

相比update和insert,一般查询应该是数据库中操作最频繁的.而在有些应用场景需要用到like模糊查询,那么对于大数据,查询的时候就要注意了.   现在来分析一下为什么like语句查询的效率会很低,测试数据共4000000条,如下图:     第一步:不使用索引 下图可以看出,不使用索引的时候普通查询与like查询的耗时相当,like略长,这也是必然的,因为它要进行额外的算法.     第二步:使用索引   如下图,使用索引后,普通查询的耗时基本算是秒查,非常快:而like查询还是耗时一秒

在iBatis中如何将查询的一些总和结果返回为List&amp;amp;lt;HashMap&amp;amp;gt;的形式?

问题描述 我的sql语句是从数据库中得到的一点简单的统计信息,我觉得没必要单独再写一个VO了,如何返回List<HashMap>形式的数据>? 解决方案 resultClass 设置下解决方案二:在ibatis3/myBatis 是resultType

vb.net-VB,net linq 模糊查询List

问题描述 VB,net linq 模糊查询List 我有 一 个书籍列 Dim books As List(Of book) 需要用textbox.text的值 对这个list进行模糊查询,返回list 结果,用循环比较浪费,LINQ 如何做 解决方案 linq 模糊查询linq 模糊查询linq中动态模糊查询

SQL 模糊查询

  在进行数据库查询时,有完整查询和模糊查询之分. SQL模糊查询,使用like比较字,加上SQL里的通配符,请参考以下: 1.LIKE'Mc%' 将搜索以字母 Mc 开头的所有字符串(如 McBadden). 2.LIKE'%inger' 将搜索以字母 inger 结尾的所有字符串(如 Ringer.Stringer). 3.LIKE'%en%' 将搜索在任何位置包含字母 en 的所有字符串(如 Bennet.Green.McBadden). 4.LIKE'_heryl' 将搜索以字母 her

sql server怎么模糊查询某几列

问题描述 sql server怎么模糊查询某几列 小白一个,正在做一个管理系统,有第一周到第二十周的数据,怎么每次通过写入第几周,把本周的数据查询出来呢 解决方案 在数据查询的时候,有完整查询和模糊查询之分.在Access和SQL Server中使用模糊查询有一下几种查询: 1.用_通配符查询 "_"号表示任意单个字符,该字符号只能匹配一个字符,利用"_"号可以作为通配符组成匹配模式进行查询."_"符号可以放在查询条件 的任意位置,且只能代表一个

大数据量中的模糊查询优化方案

----------------------------------------------------------------------------------------------[版权申明:本文系作者原创,转载请注明出处] 文章出处:http://blog.csdn.net/sdksdk0/article/details/52589761作者:朱培      ID:sdksdk0      ------------------------------------------------

mysql模糊查询like和regexp小结_Mysql

在mysql中实现模糊查询的有like和regexp. ------------------------ like的用法许多人都是知道的,最为常用的情况就是select * from a where name like '%a%'; 其中'%'代表的是任意个字符,它的效果像是正则表达式里的'*',它有几种用法:'a%','%a%','%a',分别表示以什么开头,存在什么以及以什么结尾. 另外也可以使用'_'字符,这表示一个任意字符.效果类似正则表达式里面的'.'. like是对这个字段里面的所有

有关SQL模糊查询_Mysql

一般模糊查询语句如下: 复制代码 代码如下: SELECT 字段 FROM 表 WHERE 某字段 Like 条件 其中关于条件,SQL提供了四种匹配模式: 1,% :表示任意0个或多个字符.可匹配任意类型和长度的字符,有些情况下若是中文,请使用两个百分号(%%)表示. 比如 SELECT * FROM [user] WHERE u_name LIKE '%三%' 将会把u_name为"张三","张猫三"."三脚猫","唐三藏"