mybatis相关介绍是什么

发布时间:2021-10-19 17:38:35 作者:柒染
来源:亿速云 阅读:116

今天就跟大家聊聊有关mybatis相关介绍是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

1.mybatis编程步骤

  1. 创建SqlSessionFactory对象

  2. 通过SqlSessionFactory获取sqlSession对象

  3. 通过sqlSession获取Mapper的代理对象

  4. 通过mapper的代理对象,执行数据库操作

  5. 执行成功,则使用sqlsession提交事务

  6. 执行失败,则使用sqlsession回滚事务

  7. 最终,关闭会话

2.#{}和${}的区别

${}是properties文件中的变量占位符,它可以用于xml标签属性值和sql内部,属于字符串替换。

<!-- ${driver} 会被替换为 com.mysql.jdbc.driver -->
<dataSource type="UNPOOLED">
    <property name="driver" value="${driver}"/>
    <property name="url" value="${url}"/>
    <property name="username" value="${username}"/>
</dataSource>

${}也可以对传递进来的参数原样拼接在sql中。实际场景中,不推荐使用${},因为会有sql注入的风险。


#{}是sql的参数占位符,mybatis会将sql中的#{}替换为?号,在sql执行前会使用PreparedStatement的参数设置方法,按序给sql的?号占位符设置参数。所以#{}是预编译处理,可以有效防止sql注入,提高系统安全性。

3.实体类的属性名和表中的字段名不一样,如何处理

    <setting name="mapUnderscoreToCamelCase" value="true" />

4.mybatis的xml映射文件中,除了常见的select|insert|update|delete标签外,还有哪些标签

参考mybatis中文文档

5.mysql的动态sql有哪些

参考mybatis中文文档

<if/> 、<where/>、 <set/>、 <choose/>、 <foreach/>、<when/>、 <otherwise/>、<trim/>

6.如何获取自动生成的主键

不同的数据库,获取自动生成的主键的方式是不同的。mysql有两种方式,代码如下

// 方式一,使用 useGeneratedKeys + keyProperty 属性
<insert id="insert" parameterType="Person" useGeneratedKeys="true" keyProperty="id">
    INSERT INTO user(name, pswd)
    VALUE (#{name}, #{pswd})
</insert>
    
// 方式二,使用 `<selectKey />` 标签
<insert id="insert" parameterType="Person" useGeneratedKeys="true" keyProperty="id">
    <selectKey keyProperty="id" resultType="long" order="AFTER">
        SELECT LAST_INSERT_ID()
    </selectKey>
        
    INSERT INTO user(name, pswd)
    VALUE (#{name}, #{pswd})
</insert>

看完上述内容,你们对mybatis相关介绍是什么有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。

推荐阅读:
  1. eclipse相关介绍
  2. MyBatis之SqlSession介绍

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

mybatis

上一篇:Digital Twin中IoT的下一个浪潮是什么

下一篇:mybatis源码如何分析反射模块

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》