18mybatis
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。
- if
- association一对一
- collection一对多
- 定义SQL语句
- 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>
- GET方法
-
3.模糊查询
- 法1:把'%#{name}%'改为"%"#{name}"%"
- 法2:(CONCAT('%',#{name},'%'))