1.mybatis编程步骤
- 创建SqlSessionFactory对象
- 通过SqlSessionFactory获取sqlSession对象
- 通过sqlSession获取Mapper的代理对象
- 通过mapper的代理对象,执行数据库操作
- 执行成功,则使用sqlsession提交事务
- 执行失败,则使用sqlsession回滚事务
- 最终,关闭会话
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>
也 可 以 对 传 递 进 来 的 参 数 原 样 拼 接 在 s q l 中 。 实 际 场 景 中 , 不 推 荐 使 用 {}也可以对传递进来的参数原样拼接在sql中。实际场景中,不推荐使用 也可以对传递进来的参数原样拼接在sql中。实际场景中,不推荐使用{},因为会有sql注入的风险。
#{}是sql的参数占位符,mybatis会将sql中的#{}替换为?号,在sql执行前会使用PreparedStatement的参数设置方法,按序给sql的?号占位符设置参数。所以#{}是预编译处理,可以有效防止sql注入,提高系统安全性。
3.实体类的属性名和表中的字段名不一样,如何处理
- 第一种:通过在查询的sql语句中定义字段别名,让字段名的别名和实体类的属性一致
- 第二种:在大多数场景下,数据库的字段名和实体类的属性名的差异,主要是一种是下划线,一种是驼峰风格。这种情况,可以直接配置如下,实现自动的下划线转驼峰的功能。
<setting name="mapUnderscoreToCamelCase" value="true" />
- 第三种,通过来映射字段名和实体类属性名的一一对应关系。
4.mybatis的xml映射文件中,除了常见的select|insert|update|delete标签外,还有哪些标签
- cache -对给定命名空间的缓存配置
- cache-ref 对其他命名空间缓存配置的引用
- resultMap 用来描述如何从数据库结果集中来加载对象
- sql 可被其他语句引用的可重用语句块
5.mysql的动态sql有哪些
、、 、 、 、、
、
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>