18mybatis-2018/08/02

  • 1.mybatis标签

    • 定义SQL语句

      • id :唯一的标识符
      • parameterType:传给此语句的参数的全路径名或别名例:com.test.poso.User或user
      • resultType :语句返回值类型或别名。注意,如果是集合,那么这里填写的是集合的泛型,而不是集合本身(resultType 与 resultMap 不能并用)
    • resultMap 标签的使用
      • 基本作用:建立SQL查询结果字段与实体属性的映射关系信息
      • 查询的结果集转换为java对象,方便进一步操作
      • 将结果集中的列与java对象中的属性对应起来并将值填充进去
    • 动态拼接SQL
      • if

        • if标签通常用于WHERE语句中,通过判断参数值来决定是否使用某个查询条件, 他也经常用于UPDATE语句中判断是否更新某一个字段,还可以在INSERT语句中用来判断是否插入某个字段的值
      • foreach
        • foreach标签主要用于构建in条件,他可以在sql中对集合进行迭代
        • collection :collection属性的值有三个分别是list、array、map三种,分别对应的参数类型为:List、数组、map集合,我在上面传的参数为数组,所以值为array
        • item : 表示在迭代过程中每一个元素的别名
        • index :表示在迭代过程中每次迭代到的位置(下标)
        • open :前缀
        • close :后缀
        • separator :分隔符,表示迭代时每个元素之间以什么分隔
      • choose
        • 类似于Java 的switch 语句,choose为switch,when为case,otherwise则为default。
    • association一对一
    • collection一对多
  • 2.乱码问题
    • GET方法

      • 在servers找到对应文件的server.xml把里边connector加一个属性:URIEncoding="UTF-8"
    • post方法
      • 配置web.xml文件
      •  <filter>
        <filter-name>cencoding</filter-name>
        <fileter-class>
        org.springframework.web.filter.CharacterEncodingFilter
        </filter-class>
        <init-param>
        <param-name>encoding</...>
        <param-value>UTF-8</...>
        </init-param>
        </filter>
        <filter-mapping>
        <filter-name>cencoding</filter-name>
        <url-pattern>/*</url-pattern>
        </filter-mapping>
  • 3.模糊查询

    • 法1:把'%#{name}%'改为"%"#{name}"%"
    • 法2:(CONCAT('%',#{name},'%'))

18mybatis的更多相关文章

随机推荐

  1. wireshark笔记(1)之工具认识

    1 下载链接  https://www.wireshark.org/ 安装只需要注意同时会安装winpcap就好了 相关链接:www.wiresharkbook.com //书籍 英文 www.wik ...

  2. 微型ORM:PetaPoco 学习资料整理

    github地址:https://github.com/CollaboratingPlatypus/PetaPoco petapoco 实体中字段去掉关联(类似于EF中的NotMap) 微型ORM:P ...

  3. Mybatis invalid comparison: java.util.Date and java.lang.String

    Mybatis的实体类是java.utils.Date类型,而在Mybatis的XML文件中,使用if判断了,不需要判断是否等于空字符串这种判断,需要人真一些 相关:https://blog.csdn ...

  4. 4 Java 如何判定是否存活或者死亡

    在堆中存放着几乎所有的对象实例,垃圾收集器在对堆进行回收前,第一件事就是要确定这些对象之中哪些还活着,哪些对象已经死去. 判断对象是否已经死亡有以下几种算法: 引用计数法算法 定义 : 给对象中添加一 ...

  5. E20170524-hm

    logging   n. <美>伐木搬运业; 记录,存入; 航行日志; inversion  n. 倒置; 转化; (尤指词序) 倒装; (染色体的) 倒位; reversion   n. ...

  6. 安装配置Eclipse Python开发插件PyDev

    一.PyDev安装的版本要求 PyDev是支持在Eclipse中进行Python程序开发的插件,Pydev官方的说法是需要安装 java 8 and Eclipse 4.6 (Neon),当然,你也可 ...

  7. MongoDB集群跨网络、跨集群同步方案

    MongoDB集群跨网络.跨集群数据同步有以下几个方案,此处只是简单介绍,不过详细描述. 1.MongoDB自带的复制方案 优点:实施简单,不需要额外的技术栈 缺点:网络双向可连通. 2.CDC同步方 ...

  8. Jedis线上的一个小坑:Redis有并发访问的数据错乱的问题

    问题现象: 业务数据有错乱,A的一些数据有好几个都是B的数据 这些业务数据在保存在Redis缓存中,怀疑是并发情况下Jedis错乱的问题 原因分析: JedisUtil里面在使用完Jedis 后释放资 ...

  9. java-异常简介

    1.简介 ############################################################### ############################### ...

  10. 190 Reverse Bits 颠倒二进制位

    颠倒给定的32位无符号整数的二进制位.例如,给定输入 43261596(二进制表示为 00000010100101000001111010011100 ),返回 964176192(二进制表示为 00 ...