MyBatis查询
1、一对多查询+一对一查询
<collection property="subResource" javaType="list" select="selectByTAndO" column="{pMenuId=child_pid,userId=userId}" ofType="Entity" >
</collection>
pMenuId和userId里面的value带到select="selectByTAndO"里面的条件
association 标签同collection
2、内置参数
【0, 1, param1, param2】是MyBatis根据参数位置自定义的名字
方法 select(Integer id,String name)
-使用@Param参数(单个参数不需要@Param)
给接口添加@Param注解,指明参数的对应关系,原因是给参数配置了@Param注解后,MyBatis就会自动将参数封装成Map类型
@Param("id") Integer id, @Param("version") String name
id = #{0,jdbcType=INTEGER} and name = #{1,jdbcType=VARCHAR}
-使用内置标准
id = #{0} and name=#{1} 或者 id = #{param1} and name=#{param2} :mybatis3.4.2以前版本
id = #{arg0} and name=#{arg1}:mybatis3.4.2或者之后的版本
-数组类型
id=#{array[0]} and name=#{array[1]}
3、javaType jdbcType
JDBC Type Java Type
CHAR String
VARCHAR String
LONGVARCHAR String
NUMERIC java.math.BigDecimal
DECIMAL java.math.BigDecimal
BIT boolean
BOOLEAN boolean
TINYINT byte
SMALLINT short
INTEGER INTEGER
BIGINT long
REAL float
FLOAT double
DOUBLE double
BINARY byte[]
VARBINARY byte[]
LONGVARBINARY byte[]
DATE java.sql.Date
TIME java.sql.Time
TIMESTAMP java.sql.Timestamp
CLOB Clob
BLOB Blob
ARRAY Array
DISTINCT mapping of underlying type
STRUCT Struct
REF Ref
DATALINK java.net.URL
4、常用标签
jdbcType=DECIMAL,INTEGER,TIMESTAMP,VARCHAR
<sql id="Base_Column_List">
name,age
</sql>
对应
<include refid="Base_Column_List" />
大于: >
小于:<
<if test="== containsKey">
</if>
<choose>
<when test="">
</when>
<when test="">
</when>
</choose>
<foreach collection="list" index="index" item="item" open="(" separator="," close=")">
#{item}
</foreach>
过去5天时间
DATE_SUB(#{time},INTERVAL 5 DAY)
返回周期两个时间之间的月数差
PERIOD_DIFF(DATE_FORMAT(endTime,'%Y%m'),DATE_FORMAT(startTime,'%Y%m'))
标签内置函数:
<if test="name.contains('xxx') or value.contains('yyy')"></if>
<if test="map.containsKey('xxx')"></if>
<foreanch collection="str.split(',')" item="item" index="index"
open="(" close=")" spearator=",">#{item}</foreach>
模糊查询:WHERE name LIKE CONCAT(CONCAT('%',#{name}),'%')
if test中可以使用java.lang.String中的所有方法
可以使用name!='' and name!=null 并可以使用or
mybatis是用OGNL表达式进行解析的,在OGNL表达式中'y'会被解析成字符,字符和String是有区别的,切记
mybatis的ONGL表达式:
https://blog.youkuaiyun.com/panchang199266/article/details/80249452 5、注意事项
<!-- 指定 resultType 返回值类型时 String 类型的,string 在这里是一个别名,代表的是 java.lang.String
对于引用数据类型,都是将大写字母转小写,比如 HashMap 对应的别名是 'hashmap'
基本数据类型考虑到重复的问题,会在其前面加上 '_',比如 byte 对应的别名是 '_byte'-->
alias 英语是别名的意思
利用
<typeAliases>
<typeAlias alias="别名" type="类名"/>
</typeAliases>
如果不指定alias,则别名为类名,别名不区分大小写,也可以为某个包下的所有类取别名
<typeAliases>
<package name="包名"/>
</typeAliases>
在这种情况下,如果想为某个类名起专有别名,可以用注解@Alias( )
-默认别名
mybatis已经为Java的数据类型起好了别名,可以直接拿来用,注意自己起的别名不要和这些相同,否则会起冲突。
Alias Mapped Type
_byte byte
_long long
_short short
_int int
_integer int
_double double
_float float
_boolean boolean
string String
byte Byte
long Long
short Short
int Integer
integer Integer
double Double
float Float
boolean Boolean
date Date
decimal BigDecimal
bigdecimal BigDecimal
object Object
map Map
hashmap HashMap
list List
arraylist ArrayList
collection Collection
iterator Iterator