一、MyBatis怎么读
MyBatis 是一款优秀的 ORM(Object-Relational Mapping)框架,它支持自定义 SQL、存储过程以及高级映射。Mybatis 实现了以 SqlSession 为中心的设计思路,并且可以和 Spring 框架无缝整合。 MyBatis 使用基于 XML 的配置文件或基于接口注解的方式告诉 MyBatis,哪些配置和映射对应哪些 Java 方法,然后 MyBatis 就可以自动生成实现类,这些生成的代码将映射到预处理语句中,以执行数据库操作。执行 SQL 时,MyBatis 提供了多样的参数绑定和数据处理机制,以及强大的缓存功能,让 Java 程序员可以用面向对象的方式轻松地操作数据库。
二、Mybatis安装
MyBatis 官网提供了详细的安装指南,主要包括两个方面:Java 环境的配置和 MyBatis 工具包的引入。
1. 下载 MyBatis
2. 将下载好的 jar 包添加到项目的类路径下
三、MyBatis去重
MyBatis 在进行查询时,经常用到去重操作。常用的方法有两种:使用 distinct
关键字和使用 group by
语句。具体实现方法如下:
1. 使用 distinct 关键字:
<select id="selectDistinctData" resultType="java.lang.String" parameterType="Map">
select distinct(${selectExpression}) from ${tableName}
</select>
2. 使用 group by 语句:
<select id="selectDistinctData" resultType="java.lang.String" parameterType="Map">
select ${selectExpression} from ${tableName} group by ${groupBy}
</select>
四、MyBatis模糊查询
MyBatis 支持模糊查询,一般有两种方式:使用 like
语句和使用正则表达式。使用方法如下:
1. 使用 like 语句:
<select id="selectLikeData" resultType="java.lang.String" parameterType="Map">
select * from ${tableName} where ${columnName} like '%${value}%'
</select>
2. 使用正则表达式:
<select id="selectRegexpData" resultType="java.lang.String" parameterType="Map">
select * from ${tableName} where ${columnName} regexp '${regex}'
</select>
五、MyBatis如何避免SQL注入问题
为避免 MyBatis 应用程序受到 SQL 注入 攻击,可以在 Mapper 文件中使用 ${}
表达式和 #{}
表达式作为查询参数。其中,#{}
表达式能够自动进行预编译参数处理,避免了 SQL 注入问题。示例如下:
<select id="selectUserData" resultType="User">
select * from user where id = #{user.id} and username = #{user.username}
</select>
六、MyBatis bind标签找不到类
在 MyBatis 的 Mapper XML 文件中,我们有时候会在 bind 标签中设置一个变量,但是会报找不到类的错误。解决方法是在 classpath 路径下添加缺少的 jar 包即可。
七、MyBatis获取数据存到Map中
MyBatis 提供了将查询结果存储到 Map 对象中的功能。示例如下:
<select id="selectUserData" resultType="java.util.Map">
select * from user where id = #{id}
</select>
八、MyBatis JDBC DB2 Spring
如果我们要使用 MyBatis 实现 JDBC 操作,我们需要将 MyBatis 作为 Spring JDBC 的 ORM 实现来使用。具体实现方法如下:
// MyBatis 配置
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="configLocation" value="classpath:mybatis-config.xml" />
<property name="mapperLocations" value="classpath*:mapper/**/*Mapper.xml" />
</bean>
<bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate">
<constructor-arg ref="sqlSessionFactory" />
</bean>
// Spring JDBC 配置
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="com.ibm.db2.jcc.DB2Driver" />
<property name="url" value="jdbc:db2://HOST:PORT/DATABASE" />
<property name="username" value="USERNAME" />
<property name="password" value="PASSWORD" />
</bean>
九、MyBatisPlus 乐观锁
MyBatisPlus 提供了非常方便的乐观锁更新机制,只需要在实体类中添加 @Version
注解,并配合在 Mapper XML 文件中的 <update>
标签即可实现乐观锁更新。示例如下:
// 实体类
@Data
public class User {
private Long id;
private String username;
private String password;
private Integer version;
}
// Mapper XML 文件
<update id="updateUser" parameterType="User">
update user set username = #{username}, password = #{password}, version = #{version} + 1
where id = #{id} and version = #{version}
</update>