·项目需求说明
1.根据id查询用户信息
2.根据用户名模糊查询用户信息
3.添加用户信息
4.更新用户信息
5.删除用户信息
·生产环境介绍
1.jdk1.7.0以上、eclipse、mysql5.1及以上
2.相关jar包
mybatis-3.2.7.jar、mysql-connector-java-5.1.7-bin.jar等
·项目整体架构
·具体实现
1.日志文件log4j.properties
# Global logging configuration
#在开发环境下日志级别要设置成DEBUG,生成环境设置成info或error
log4j.rootLogger=DEBUG, stdout
# Console output...
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n
2.mybatis运行环境配置 SqlMapConfig.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!-- 和spring整合后 environments配置将废除-->
<environments default="development">
<environment id="development">
<!-- 使用jdbc事务管理-->
<transactionManager type="JDBC" />
<!-- 数据库连接池-->
<dataSource type="POOLED">
<property name="driver" value="${jdbc.driver}" />
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
</dataSource>
</environment>
</environments>
</configuration>
3.创建业务实体po类
public class User {
private int id;
private String username;//用户名
private String sex;// 用户性别
private Date birthday;// 生日
}
4.相关业务xml文件(配置sql语句)
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- namespace命名空间,作用就是对sql进行分类化管理,理解sql隔离
注意:使用mapper代理方式开发,namespace有特殊重要的作用,namespace 等于mapper接口地址
-->
<mapper namespace="cn.itcast.mybatis.mapper.UserMapper">
<!--在映射文件中配置很多sql语句 -->
<!-- 需求:通过id查询用户表的记录 -->
<!-- 通过select执行数据库查询
id:标识映射文件的sql
将sql语句封装到mappedStatement对象中,所以将id称为Statement的id
parameterType:指定输入参数的类型,这里指定int型。
#{}表示一个占位符
#{id}:其中的id表示接收输入的参数,参数名称就是id,如果输入参数是简单类型,#{}中的参数名可以任意,可以value或者其他名称
resultType:指定sql输出结果的所映射的java对象类型,select指定resultType表示将单条记录英社称的java对象。
-->
<select id="findUserById" parameterType="int" resultType="cn.itcast.mybatis.po.User">
SELECT * FROM USER WHERE id=#{value}
</select>
<!-- 添加用户
parameterType:指定输入参数是pojo(包括用户信息)
#{}中指定pojo的属性名,接收到pojo对象的属性值,mybatis通过OGNL获取对象的属性值
-->
<insert id="insertUser" parameterType="cn.itcast.mybatis.po.User">
<!-- 将插入数据的主键返回,返回到user对象中
SELECT LAST_INSERT_ID():得到刚insert进去记录的主键值,只适用与自增主键
keyprooperty:将查询到的主键值设置到parameterType指定的对象的哪个属性
order:SELECT LAST_INSERT_ID()执行顺序,相当于insert语句来说它的执行顺序
resultType:指定SELECT LAST_INSERT_ID()的结果类型。
-->
<selectKey keyProperty="id" order="AFTER" resultType="java.lang.Integer">
SELECT LAST_INSERT_ID()
</selectKey>
insert into user(username,birthday,sex,address)value(#{username},#{birthday},#{sex},#{address})
</insert>
<!-- 删除用户 (根据id删除用户,需要输入id值) -->
<delete id="deleteUser" parameterType="java.lang.Integer">
delete from user where id=#{id}
</delete>
<!-- 根据id更新用户(分析:需要传入用户的id,需要传入用户的更新信息 parameterType指定user对象,包括id和更新信息,注意:id必须存在) -->
<update id="updateUser" parameterType="cn.itcast.mybatis.po.User">
update user set username=#{username},birthday=#{birthday},sex=#{sex},address=#{address} where id=#{id}
</update>
</mapper>
5.在mybatis配置文件(SqlMapConfig.xml)中加载xml(UserMapper.xml)映射文件
<!-- 加载映射文件 -->
<mappers>
<mapper resource="sqlmap/User.xml"/>
<mapper resource="mapper/UserMapper.xml"/>
</mappers>
6.具体业务实现
1)创建接口层DAO
public interface UserDao {
//根据用户id查询用户信息
public User findUserById(int id)throws Exception;
//根据用户名列查询用户列表
public List<User>findeUserByName(String name)throws Exception;
//添加用户信息
public void insertUser(User user)throws Exception;
//删除用户信息
public void deleteUser(int id)throws Exception;
}
2)创建实现类DAOImpl
public class UserDaoImpl implements UserDao{
private SqlSessionFactory sqlSessionFactory;
//注入sqlsessionFactory
public UserDaoImpl(SqlSessionFactory sqlSessionFactory){
this.sqlSessionFactory=sqlSessionFactory;
}
//根据id查询用户信息,返回一条数据。
@Override
public User findUserById(int id) throws Exception {
SqlSession sqlSession=sqlSessionFactory.openSession();
return sqlSession.selectOne("test.findUserById",id);
}
//添加用户信息
@Override
public void insertUser(User user) throws Exception {
SqlSession sqlSession=sqlSessionFactory.openSession();
//执行插入操作
sqlSession.insert("test.insertUser",user);
//提交事务
sqlSession.commit();
//释放资源
sqlSession.close();
}
//删除用户信息
@Override
public void deleteUser(int id) throws Exception {
SqlSession sqlSession=sqlSessionFactory.openSession();
//执行插入操作
sqlSession.delete("test.deleteUser", id);
//提交事务
sqlSession.commit();
//释放资源
sqlSession.close();
}
//根据用户名模糊查询用户信息
@Override
public List<User> findeUserByName(String name) throws Exception {
SqlSession sqlSession=sqlSessionFactory.openSession();
//执行查询操作
return sqlSession.selectOne("test.findUserById",name);
}
}
·小结
至此,Mybatis最简单的增删改查小实例展示完成。大家可以清楚的看到Mybatis中,所有的sql语句全部放到了xml文件中,在运行时通过扫描的方式加载这些xml文件配合完成程序执行。在这其中,重中之重就是配置文件的映射问题。大家有兴趣的话,可以按照我的实例总结,进行实战学习。不足之处,多多指教!