首页 > 技术文章 > Mybatis实战-入门程序

fengkungui 2016-10-08 17:28 原文

·项目需求说明
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文件配合完成程序执行。在这其中,重中之重就是配置文件的映射问题。大家有兴趣的话,可以按照我的实例总结,进行实战学习。不足之处,多多指教!

推荐阅读