view plain copy print?

  1. dynamic可以去除第一个prepend="and"中的字符(这里为and),从而可以帮助你实现一些很实用的功能。具体情况如下:
  2. 1.使用dynamic
  3. 1.1 xml
  4. select * from Person表
  5. <dynamic prepend="where">
  6. <isNotNull property="name" prepend="and">
  7. name=#name#
  8. </isNotNull>
  9. <isNotNull property="sex" prepend="and">
  10. sex=#sex#
  11. </isNotNull>
  12. </dynamic>
  13. 1.2 结果
  14. 当name、sex都非null时打出如下的sql语句:
  15. select Person表 where (and) name= ? , and sex= ?
  16. 显然name前的and被自动去除了,很方便吧。
  17. 2.不使用dynamic
  18. 2.1 xml
  19. 如果我把dynamic 去掉就会变的很恶心,如下:
  20. select * from Person表
  21. <isNotNull property="name" prepend="and">
  22. name=#name#
  23. </isNotNull>
  24. <isNotNull property="sex" prepend="and">
  25. sex=#sex#
  26. </isNotNull>
  27. 2.2 结果
  28. 当name、sex都非null时打出如下的sql语句:
  29. select Person表 where and name= ? , and sex= ?
  30. 显然name前多个and,sql语句错误。
  31. 3.总结
  32. dynamic 会自动去除第一个 prepend="and中的内容(这里为and),从而方便一些操作。

解決and存在問題 在开发过程 中 sql 语句后面写上where 1=1

这样就算不适用dynamic 也不需要消除and 就可以使用sql语句不会报错

SELECT *
   FROM (SELECT ROWS_.*, ROWNUM ROWNUM_
           FROM (select user_id,
                        user_name,
                        status,
                        user_type,
                        organ_id,
                        login_name,
                        password,
                        tel,
                        email,
                        sex
                   from sys_user
                  where 1 = 1
                    and sys_user.user_id = 114833
                  order by user_id) ROWS_
          WHERE ROWNUM <= 10)
  WHERE ROWNUM_ >= 1

ibatis (六) dynamic的用法的更多相关文章

  1. ibatis dynamic的用法

    <select id="idididid" resultClass="java.uitl.HashMap" parameterClass="ja ...

  2. iBatis一些非见用法(相当实用)

     兼顾效率,iBatis一些非见用法(10条) 2009-09-18 10:33:03 标签:iBatis 休闲 职场 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声 ...

  3. Ibatis动态(dynamic)查询

     Ibatis的动态查询使得数据操作变得非常的灵活,下次举出了常用的动态查询的属性信息: Ibatis配置信息 <!-- Dynamic Sql --> <typeAlias a ...

  4. ibatis中iterate的用法(conjunction="or" ",")

    例子一 查询条件dto public class queryCondition{ private String[] stuIds; private String name;} 查询sqlMap < ...

  5. @property、@synthesize和dynamic的用法

    原文:  http://blog.csdn.net/hherima/article/details/8622948 @代表“Objective-C”的标志,证明您正在使用Objective-C语言 O ...

  6. var,dynamic的用法

    private void Form1_Load(object sender, EventArgs e) { var dt = Getuser() as IEnumerable<dynamic&g ...

  7. ibatis.net:惯用法

    使用<![CDATA[]]>保持SQL格式 IN 查询

  8. 理解C# 4 dynamic(1) - var, object, dynamic的区别以及dynamic的使用

    阅读目录: 一. 为什么是它们三个 二. 能够任意赋值的原因 三. dynamic的用法 四. 使用dynamic的注意事项 一. 为什么是它们三个? 拿这三者比较的原因是它们在使用的时候非常相似.你 ...

  9. C#dynamic关键字(1)

    一.object,var,dynamic的区别 static void Main() { //var是C# 3中引入的,其实它仅仅只是一个语法糖. var本身并不是一种类型, 其它两者object和d ...

随机推荐

  1. 阿里四不像Fourinone

    阿里四不像——分布式核心技术框架 Fourinone https://blog.csdn.net/shero_zsmj/article/details/52277194

  2. googletest--Death Test和Exception Test

    Death Test验证某个状态会使进程以某个错误码和错误消息离开 #include <gtest\gtest.h> #include "MyStack.h" // D ...

  3. node升级的正确方法

    本文主要是针对安装了node的用户如何对node进行升级或者安装指定版本:没有安装node的可以参考连接node安装方法 . 安装方法: 1.产看node版本,没安装的请先安装: $  node -v ...

  4. javascript mqtt 发布订阅消息

    js client使用paho-mqtt,官网地址:http://www.eclipse.org/paho/,参考http://www.eclipse.org/paho/clients/js/官网给出 ...

  5. problem: vue中获取动态元素高度

    前言:始终要相信你能想到的解决方案,基本上都是可以用技术实现的... 解决方法就是在mounted中在this.$nextTick()去获取,如果没有获取到,不是写法错就是,元素没有绑定对地方,注意检 ...

  6. python之路——14

    王二学习python的笔记以及记录,如有雷同,那也没事,欢迎交流,wx:wyb199594 复习 1.迭代器 1.双下方法:不常直接调用,是通过其他语法触发的 2.可迭代的:可迭代协议——含有__it ...

  7. html/css/js-layer弹出层的初次使用

    学习前端有时很多时候要用到弹出层,原生的js写有些麻烦,而且不美观,基于jQuery的弹出层组件layer应运而生,近些年来备受青睐.官网上有使用教程,但当初用的时候还是糊里糊涂,今天来记录一下lay ...

  8. POJ3259 Wormholes

    Description While exploring his many farms, Farmer John has discovered a number of amazing wormholes ...

  9. java使用jdbc连接oracle(其他数据库类似)

    最基本的Oracle数据库连接代码: 1.右键项目->构建路径->配置构建路径,选择第三项“库”,然后点击“添加外部Jar”,选择“D:\Oracle\app\oracle\product ...

  10. 【Linux】【Jenkins】系统配置报反向代理设置有误问题的解决方案

    1.如图所示: 2.点击更多信息,查看解决办法: https://wiki.jenkins-ci.org/display/JENKINS/Jenkins+says+my+reverse+proxy+s ...