Mybatis-查询

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" />

                    大于: &gt;
                    小于:&lt;

            <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.csdn.net/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  
                
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值