zoukankan      html  css  js  c++  java
  • iBatisSQL中prepend的问题

    是前向声明还是后向声明?

    官方文档那个给出:“the overridable SQL part that will be prepended to the statement”。可见是前向声明。

    ---------------------------分割线---------------------------------------------

    以下内容转自:http://blog.csdn.net/woshixuye/article/details/8063710

    关于ibatis动态sql的prepend的属性,我们需要理解一下几点

    select * from student
    <dynamic prepend="where">
     <isNotNull property="id" prepend="and">
      id = #id#
     </isNotNull>
     <isNotNull property="name" prepend="and">
      name like '%$name$%'
     </isNotNull>
    </dynamic>

    要点一  prepend是添加在动态语句的前面

    and是添加在id = #id#,同样and是添加在name like '%$name$%'前面

    要点二  dynamic中首个prepend被忽略

    按照要点一说法,语句select * from studnet and id = #id#就会出现问题了。其实若<isNotNull>写在<dynamic>里,且包含prepend,第一个isNotNull的prepend会被忽略。有的人会说,id不加prepend,变成<isNotNull property="id">?那就错了,因为name前面的and会被过滤掉了,会出错。

    要点三  明白了要点二,可以理解拼接语句中遇到的一些错误问题

    --------------------------------分割线结束-----------------------------------------------

  • 相关阅读:
    模板语法
    django框架中登陆验证功能
    __call__
    JQuery基础
    JS中BOM和DOM操作
    Javascript基础
    css完结
    css深入
    css初识
    html深入解析
  • 原文地址:https://www.cnblogs.com/GYoungBean/p/3198474.html
Copyright © 2011-2022 走看看