spring mvc、meven结合mybatis
来源:互联网 发布:mysql 连续 天 统计 编辑:程序博客网 时间:2024/06/07 11:05
mybatis可以说是一个很不错的数据库操作库,相比于hibernate来说,mybatis更加灵活,需要自己写sql语句来实现数据库的操作,但是可以把全部的数据库操作语句都放在一起管理,这样就避免了我们将要去代码里面找到sql语句,然后在执行相应的优化和修改的步骤,而且hibernate不能自己配置sql语句,对于小型项目来说,可能是很不错的选择,但是当我们需要自己优化项目的时候,就会出现捉襟见肘的局面,所以自学了一下mybatis框架的使用。
在集成了springmvc的meven项目框架中,想要加入mybatis还是很方便的,只需要在pom.xml里面加入mybatis的依赖,同时也要加入mysql-connector-java的依赖,因为我们使用的mysql数据库,所以需要这个数据库连接的管理,但是我在使用的时候,发现eclipse中的meven找不到mybatis的依赖,这个时候可以自己去mybatis的官网里面下载mybatis的jar包,在项目中引入依赖
http://blog.mybatis.org/里面下载依赖就好,这里下载的是3.4.4版本的jar包
在src/main/resources下面加入mybatis-config.xml的mybatis依赖配置,这里有一份简单的配置
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configuration PUBLIC "-//ibatis.apache.org//DTD Config 3.0//EN" "http://ibatis.apache.org/dtd/ibatis-3-config.dtd"> <configuration> <!--配置日志,使用log4j日志--> <settings> <setting name="logImpl" value="log4j"></setting> </settings> <!--配置数据库连接环境,这里使用mysql数据库--> <environments default="environment"> <environment id="environment"> <!--事务管理器,使用JDBC--> <transactionManager type="JDBC" /> <!--数据库连接池的方式--> <dataSource type="POOLED"> <!--数据库驱动--> <property name="driver" value="com.mysql.jdbc.Driver" /> <property name="url" value="jdbc:mysql://localhost:3306/spring?characterEncoding=UTF-8" /> <property name="username" value="root" /> <property name="password" value="vbklio" /> </dataSource> </environment> </environments> <!--一些mapper文件,就是我们操作数据库的SQL语句,最好和我们的实体属性相对--> <mappers> <mapper resource="mybatis/UserMapper.xml"/> <mapper resource="mybatis/StudentMapper.xml"/> </mappers></configuration>
比如一个mapper文件,就是上面配置的对于User模型的mapper
mybatis/UserMapper.xml
<?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"><!-- 命名空间mapper:com.model.professional --><mapper namespace="uc.meven.test2.UserMapper"> <resultMap id="userResultMap" type="uc.meven.test2.modal.UserTest"> <id property="id" column="id"/> <result property="name" column="name"/> <result property="sex" column="sex"/> <result property="age" column="age"/> </resultMap> <insert id="save" parameterType="uc.meven.test2.modal.UserTest" useGeneratedKeys="true"> <!-- 底层的SQL语句 --> INSERT INTO tb_user(name,sex,age) VALUES(#{name},#{sex},#{age}) </insert> <update id="update" parameterType="uc.meven.test2.modal.UserTest"> UPDATE tb_user SET name=#{name},sex=#{sex},age=#{age} WHERE id=#{id} </update> <select id="select" parameterType="int" resultType="uc.meven.test2.modal.UserTest"> SELECT * FROM tb_user WHERE id=#{id} </select> <select id="selectAll" resultMap="userResultMap"> SELECT * FROM tb_user </select> <delete id="delete" parameterType="int"> DELETE FROM tb_user WHERE id=#{id} </delete></mapper>
在我们的数据库操作中只需要简单的开启一个事务连接,调用相应的mapper方法,就可以对数据库进行操作了
//获取相应的mybatis配置InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);SqlSession session = sqlSessionFactory.openSession();// 创建一个要操作的数据实例UserTest user = new UserTest("小明2", "男", 28);// 调用相应的mapper来进行相应的数据库操作session.insert("uc.meven.test2.UserMapper.save", user);// 提交事务session.commit();// 关闭连接session.close();
这样我们就可以简单的实现我们的数据库操作了
一般我们都会将操作方式再封装一层,通过接口类的方式来实现对mapper的调用,如上面的对User的操作,实现一个UserMapper的接口类
package uc.meven.test2;import uc.meven.test2.modal.UserTest;public interface UserMapper { UserTest select(int id);}
注意这里的接口包名和接口名要和我们在UserMapper.xml中声明的命名空间一样,不然会找不到相应的mapper对象
然后在进行数据库操作的时候,直接获取这个接口类就好
InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);SqlSession session = sqlSessionFactory.openSession();// 获取相应的mapper接口类UserMapper um = session.getMapper(UserMapper.class);// 直接调用接口类里面声明的方法和我们在UserMapper.xml中的数据库操作对应UserTest user = um.select(1);// 提交事务session.commit();// 关闭连接session.close();
这样也能实现我们想要的结果
或者我们也可以将sql语句以注解的方式写在相应的接口类方法上,如上面的
package uc.meven.test2.mapper;import org.apache.ibatis.annotations.Select;import uc.meven.test2.modal.UserTest;public interface UserMapper { @Select("SELECT * FROM tb_user WHERE id=#{id}") UserTest select(int id);}
这个时候,我们需要把我们的mapper.xml文件中相应的sql操作语句去掉,不然会出现重复定义的问题,但是那个maper.xml文件还是需要的,也就是说我们的sql语句可以写在注解或者是xml文件中,两者二选一就好
- spring mvc、meven结合mybatis
- mybatis学习笔记一mybatis结合spring mvc配置
- mybatis-generator-meven-plugin
- MyBatis与Spring结合:
- Spring和Mybatis结合
- spring,mybatis,struts2结合
- Mybatis与Spring结合
- Spring、Mybatis 结合 Hadoop
- Spring MVC 结合Junit4
- mybatis 入门到精通 (五) mybatis 于 spring mvc 结合
- mybatis学习笔记二mybatis结合spring mvc实现(用户登录,数据查询)
- spring+mybatis+spring-mvc
- Spring +Spring MVC+Mybatis
- jquery datatable 结合spring mvc mybatis和spring data Pageable分页
- meven
- mybatis搭建spring mvc
- Spring MVC Mybatis 整合
- spring mvc mybatis 整合
- 排序算法性能对比
- 如何在页面上减少用户操作?
- 详细讲解Android View的绘制流程
- select函数详解
- ActiveMq持久订阅小例子
- spring mvc、meven结合mybatis
- 计算机系统漫游
- 【JZOJ5060】【GDOI2017第二轮模拟day1】公路建设
- Linux系统编程第14章-系统编程概念
- 文章标题
- 最小差
- CodeForces
- 自己实现的库函数(memset,memcmp,memcpy,memmove)
- 【Matlab数据的可视化】自适应绘图函数fplot