Mybatis实战-入门程序

来源:互联网 发布:vb关机代码 编辑:程序博客网 时间:2024/04/28 09:38

·项目需求说明
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或errorlog4j.rootLogger=DEBUG, stdout# Console output...log4j.appender.stdout=org.apache.log4j.ConsoleAppenderlog4j.appender.stdout.layout=org.apache.log4j.PatternLayoutlog4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n

2.mybatis运行环境配置 SqlMapConfig.xml

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE configurationPUBLIC "-//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 mapperPUBLIC "-//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文件配合完成程序执行。在这其中,重中之重就是配置文件的映射问题。大家有兴趣的话,可以按照我的实例总结,进行实战学习。不足之处,多多指教!

0 0
原创粉丝点击