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
- Mybatis实战-入门程序
- 【Mybatis进阶】--mybatis 入门程序
- Mybatis实战一之入门
- mybatis入门实战之CRUD
- mybatis实战教程,mybatis入门到精通
- mybatis入门程序
- Mybatis入门程序
- Mybatis入门程序
- mybatis入门程序
- mybatis--入门程序
- MyBatis (二) 入门程序
- Mybatis入门程序一
- mybatis的入门程序
- mybatis入门程序
- MyBatis 入门程序
- MyBatis入门小程序
- Mybatis入门程序
- Mybatis入门程序
- PHP基础教程十二之抽象、接口
- socket udp
- struct sockaddr与struct sockaddr_in ,struct sockaddr_un的区别和联系
- 动态查找——哈希表
- 头文件互相的问题
- Mybatis实战-入门程序
- LightOJ1086-Jogging Trails -状态压缩,欧拉回路
- Debug Knowledge Base 1
- windbg 设置路径
- cmake demo windows
- bat 删除目录
- 年轻为何要迷茫, 语录收藏
- _tWinMain无法解析_main
- 从Win32程序中的主函数中获取命令行参数 _twinmain