欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

18mybatis

程序员文章站 2022-12-16 12:38:29
18mybatis-2018/08/02 1.mybatis标签 定义SQL语句 id :唯一的标识符 parameterType:传给此语句的参数的全路径名或别名例:com.test.poso.User或user resultType :语句返回值类型或别名。注意,如果是集合,那么这里填写的是集合 ......

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文件
      •  1 <filter>
         2     <filter-name>cencoding</filter-name>
         3     <fileter-class>
         4         org.springframework.web.filter.characterencodingfilter
         5     </filter-class>
         6     <init-param>
         7         <param-name>encoding</...>
         8         <param-value>utf-8</...>
         9     </init-param>
        10 </filter>
        11 <filter-mapping>
        12     <filter-name>cencoding</filter-name>
        13     <url-pattern>/*</url-pattern>
        14 </filter-mapping> 
  • 3.模糊查询

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