在通常情况下iBATIS的参数在sqlmap中使用#param#的形式,参数名以’#’包着,但当使用sql的LIKE语句时就发生了问题,在单引号中无法使用#param#这种形式,下面列举出了3种方法来实现:

当应用SELECT * FROM TABLE WHERE COL LIKE ’value%’时如果要把’value’以参数代替,可以把整个LIKE后面的字符串全改为参数,即 SELECT * FROM TABLE WHERE COL LIKE #param#,此时参数param的值为字符串"value%"。但有时上面这种情况会使程序变复杂,所以用参数只代替’value’时就要碰到在单引号内使用参数的问题。这时是使用’$’将参数名包起来,即SELECT * FROM TABLE WHERE COL LIKE ’$param$%’,此时参数param的值就是字符串"value"。

在网上看到另一种方法,就是SELECT * FROM TABLE WHERE COL LIKE #param#||’%’。这个方法我试过了,是无效的的,mysql中"||"代表程序中的OR,无法正常运行。但是可以通过mysql的字符串了连接函数:contat来实现,将字符串连接起来,这样就可以了,SELECT * FROM TABLE WHERE COL LIKE contat(#param#,’%’)

方法三:在通常情况下iBATIS的参数在sqlmap中使用#param#的形式,参数名以’#’包着,但当使用sql的LIKE语句时就发生了问题,在单引号中无法使用#param#这种形式当应用SELECT * FROM TABLE WHERE COL LIKE ’value%’时如果要把’value’以参数代替,可以把整个LIKE后面的字符串全改为参数,即 SELECT * FROM TABLE WHERE COL LIKE #param#,此时参数param的值为字符串"value%"。

最新文章

  1. C#编程总结(八)数字签名
  2. $("<div />")代表的意思
  3. loadlibrary DLL 0失败 的一个原因。
  4. panels能否包含views_block ////// panels -- content pane 参数传递
  5. chromium 安装 pepper flash player
  6. JS焦点图 上下翻动 支持IE6
  7. C++ STL之查找算法
  8. [三]SpringMvc学习-封装、乱码问题、重定向、转发
  9. C#黑白棋制作~
  10. ASP.NET得到系统相关信息
  11. VS2015 Cordova Ionic移动开发(四)
  12. 如果数据为null,则转成数据库可识别的DBNULL.Value
  13. Android下实现数据绑定功能
  14. Django中ORM介绍和字段及字段参数
  15. nginx常用配置
  16. CenterOS下安装NodeJS
  17. Android如何实现TCP和UDP传输
  18. Entity Framework 6 和 MVC5
  19. 使用Generator(小黑鸟)反向生成Java项目(IDEA + Maven)
  20. 跟我学Spring Cloud(Finchley版)-20-Spring Cloud Config-Git仓库配置详解 原

热门文章

  1. 树和二叉树在java中
  2. delphi自带的SHA1算法
  3. Python学习-18.Python中的错误处理(三)
  4. Thread in depth 4:Synchronous primitives
  5. Docker Compose 部署前后端分离应用
  6. 使用Commons Email发送邮件
  7. OpenStack kolla 多 region 部署配置
  8. 《Python绝技:运用Python成为顶级黑客》 用Python分析网络流量
  9. jQuery基础笔记(4)
  10. Ubuntu 16.04LTS安装Nginx