2020-04-20 Mybatis相关知识

Mybatis相关知识

Mybatis之多参传递

注解方式传递参数

1.在mappper.xml中编写相关sql语句

<select id="findUserByNameAndSex" resultType="User">
    select * from user where username = #{name} , sex = #{sex}
</select>

2.在接口中用注解传递参数

//注解方式传多个参数,xml里不用写parameterType
    public Users findUserByNameAndSex(@Param("name")String name,@Param("sex")String sex);   

3.也可以使用注解方式编写sql语句

@Select("select * from user where username = #{name} , sex = #{sex}")
    public Users findUserByNameAndSex2(@Param("name")String name,@Param("sex")String sex);

包装类传递参数

将所需参数封装到一个包装类里
特别地:如果需要将一个类作为参数封装到一个包装类里,调这个类里的属性需要用 "."

<!-- 包装类中参数是一个封装类,采用. 调用封装类里的属性   名字要一样 -->
    <select id="findUserByUserVo" parameterType="usersQueryVo" resultType="users">
        select * from users where username like "%"#{users.username}"%"
    </select>

Map方式

一般用于只传递两个参数进入查询语句,将这两个参数封装到Map中。
在mapper中,Map默认别名为map

<!-- Map默认别名 map -->
<select id="" parameterType="map"></select>

别名

别名:实体类中的名字与数据库中的不一致。使用resultMap高级映射
resultMap用于高级映射 实体类与表不一致,自定义结果映射集 type:指向映射的对象类
<id/>:匹配主键 column:表里的列名
property:实体类的属性名

在xml文件里设置别名

<resultMap type="Orders" id="orders">
    <id column="id" property="id"/>
    <result column="user_id" property="userId"/>
</result>
//column 是数据库中的名字   property 是类中的属性
<select id="selectOrderList" resultMap=" orders">
    select id,user_id,number FROM orders
</select>   
//resultType改为resultMap  resultMap中的内容与id一致

sql语句拼接

利用动态sql实现根据用户传入参数不同,自动完成查询条件的变化

查询中常用的sql语句拼接

where: 相当于sql中的where 不同是where标签不会编辑到sql中 where会去前and
if:判断 test:判断条件
Integer默认值是"" , 但int默认值为0 建议使用integer

实例:

<!-- 根据性别和名字查询用户 where 可以在sex为null或空值时 去掉username前的 and 但不能去掉后 and -->
<select id="selectUserBySexAndUsername" parameterType="User" resultType="User">
    select * from user
    <where>
        <if text="sex != null and sex != ' '">
            sex = #{sex}
         </if>
         <if test="username !=null and username != ' '">
             and username = #{username}
          </if>
    </where>
 </select>  

增加中常用的sql语句

<insert id="insertUserByExample" parameterType="users">
        insert into users 
        <trim prefix="(" suffix=")"  suffixOverrides=",">
            <if test="id != null and '' != id">
                id,
            </if>
            <if test="username != null and '' != username">
                username,
            </if>
        </trim>
        <trim   prefix="values(" suffix=")" suffixOverrides=",">
            <if test="id != null and '' != id">
                #{id},
            </if>
            <if test="username != null and '' != username">
                #{username},
            </if>
        </trim>
    </insert>

sql语句封装

定义sql片段

可以将常用的sql语句单独定义出来,需要的时候调用

<sql id="findsql">
     select * form users
</sql>
<!-- include:应用已定义的sql语句 -->
<select id="findUser" resultType="users">
    <include refid="findsql" ></include>
</select>

封装到类

将sql语句封装到类里,在接口中调用封装类

@SelectProvider(type = UserSqlProvider.class,method="queryUserById")
    public Users findUserById(Integer id);

封装类

    public String queryUserById(int id) {
        return "select * from user where id = #{id}";
    }
    //注意and 前面的空格
    public String queryUserByExample(Users user) {
        String sql = "select * from user where 0=0";
        if(null != user.getId()) {
            sql+=" and where id = #{id}";
        }
        if(user.getName() != null) {
            sql+=" and name  = #{name}";
        }
        return sql;
    }
    

结构化sql语句

//结构化sql语句
    public String queryUserByName() {
        //String sql = "select * from user where name like '%'#{name}'%'";
        SQL sql = new SQL();
        String str=sql.SELECT("*").FROM("user").WHERE("name like concat('%',#{name},'%')").toString();
        return str;
    }

sql语句中的遍历

在sql语句中传入一个集合,然后遍历集合中的数据,用于执行相关操作
foreach:遍历 如果是集合,直接传递过来List Map 和Array 有默认别名 首字母小写
item:遍历时的元素
open:开始遍历时添加
close:遍历结束时添加
separator:不同元素之间的分隔符
如果是在传进来的封装类中有一个list属性,collection里直接写数组的属性名

<select id="findUserBatchById" resultType="user" parameterType="int">
        select * from user where id IN
            <foreach collection="list" item="i" index="" open="(" close=")" separator=",">
                #{i}
            </foreach>
    </select>

注解式遍历

@Select({"<script>",
            "select * from user",
            "<where>" , 
            "<if test='id!=null '>id=#{id}</if>", 
            "</where>",
            "</script>"})
    public List<Users> findUserByExample(Users user);
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,214评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,307评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,543评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,221评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,224评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,007评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,313评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,956评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,441评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,925评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,018评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,685评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,234评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,240评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,464评论 1 261
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,467评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,762评论 2 345

推荐阅读更多精彩内容