Mybatis(五):Mybatis的三种使用方式
注意,这篇文章只介绍mybatis单独使用时如何操作,是没有用到spring的,如果需要了解mybatis和spring如何搭建,请移步这里Mybatis(六):spring与mybatis三种整合方法。
方式一:不使用mapper接口
步骤
1.pom文件里添加jar包
- <dependency>
- <groupId>org.mybatis</groupId>
- <artifactId>mybatis</artifactId>
- <version>3.3.0</version>
- </dependency>
2.准备Mybatis的配置文件
- <?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>
- <settings>
- <!-- 打印查询语句 -->
- <setting name="logImpl" value="STDOUT_LOGGING" />
- </settings>
- <!-- 和Spring整合后environment配置都会被干掉 -->
- <environments default="development">
- <environment id="development">
- <!-- 使用jdbc事务管理,目前由mybatis来管理 -->
- <transactionManager type="JDBC" />
- <!-- 数据库连接池,目前由mybatis来管理 -->
- <dataSource type="POOLED"><!--有关于mysql数据库的各种信息-->
- <property name="driver" value="com.mysql.jdbc.Driver" />
- <property name="url" value="jdbc:mysql://localhost:3306/mybatis" />
- <property name="username" value="root" />
- <property name="password" value="123456" />
- </dataSource>
- </environment>
- </environments>
- <mappers>
- <!--将操作配置文件User.xml系添加进mapper-->
- <mapper resource="mybatis/user.xml" />
- </mappers>
- </configuration>
更多的参数配置,参阅:Mybatis(一):MyBatis配置文件config.xml详解
3.准备实体类
- public class User {
- private String id;
- private String password;
- private String username;
- public String getId() {
- return id;
- }
- public void setId(String id) {
- this.id = id;
- }
- public String getPassword(){
- return password;
- }
- public void setPassword(String password){
- this.password=password;
- }
- public String getUsername(){
- return username;
- }
- public void setUsername(String username){
- this.username=username;
- }
- }
4.准备实体对应的mapper映射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 namespace="user"> <!-- 注意,因为这边没有用到mapper接口,所以这里的namespace不需要是完全的类名 -->
- <!-- 通过id查询用户 -->
- <select id="findUserById" parameterType="int" resultType="com.mvc.User">
- <include refid="selectStr"/> id = #{id}
- </select>
- <!--通过name查找一个list的用户,模糊匹配-->
- <select id="findUserByName" parameterType="java.lang.String" resultType="com.mvc.User">
- select * from user where name like '%${value}%'
- </select>
- <!--插入用户信息-->
- <insert id="insertUser" parameterType="com.mvc.User">
- <selectKey keyProperty="id" order="BEFORE" resultType="java.lang.String">
- select uuid()
- <!-- 这里是对于主键属性的id进行赋值 -->
- </selectKey>
- insert into user(id,username,password) values(#{id},#{username},#{password})
- </insert>
- <!--删除用户信息-->
- <delete id="deleteUser" parameterType="java.lang.Integer">
- delete from user where id=#{id}
- </delete>
- <!--更新用户信息-->
- <update id="updateUser" parameterType="com.mvc.User">
- <!-- update user set name=#{name},password=#{password} where id=#{id} -->
- update user
- <set>
- <if test="username != null && username != ''">username=#{username},</if>
- <if test="password != null && password != ''">password=#{password},</if>
- </set>
- where id= #{id}
- </update>
- </mapper>
5.准备一个获取sqlsession的工具类
- import java.io.IOException;
- import org.apache.ibatis.io.Resources;
- import org.apache.ibatis.session.SqlSession;
- import org.apache.ibatis.session.SqlSessionFactory;
- import org.apache.ibatis.session.SqlSessionFactoryBuilder;
- public class MybatisSessionUtil {
- static SqlSessionFactory sqlSessionFactory = null;
- static{
- SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
- try {
- sqlSessionFactory = sqlSessionFactoryBuilder.build(Resources.getResourceAsStream("mybatis-config.xml"));
- } catch (IOException e) {
- e.printStackTrace();
- }
- }
- public static SqlSession getSession(){
- return sqlSessionFactory.openSession();
- }
- }
6.准备dao
- import org.apache.ibatis.session.SqlSession;
- import com.mvc.User;
- import com.mybatis.mapper.User2Mapper;
- public class UserDao {
- SqlSession session = MybatisSessionUtil.getSession();
- public int insert(User user){
- int rint = session.insert("user.insertUser",user); // 第一个参数是mapper xml里的namespace+MappedStatement对应的id
- session.commit();// 不要忘记提交
- return rint;
- }
- }
7.看下数据里user表
8.测试类
- import com.mvc.User;
- import com.mybatis.util.UserDao;
- public class MybatisNoSpringTest {
- public static void main(String[] args) {
- UserDao userDao = new UserDao();
- User user = new User();
- user.setUsername("wwwttt");
- user.setPassword("33333");
- if (userDao.insert(user) == 1) {
- System.out.println("insert success...");
- }else{
- System.out.println("insert fail...");
- }
- }
- }
方式二:使用mapper接口
步骤
1.pom文件里添加jar包
同方式一
2.准备Mybatis的配置文件
同方式一,就是换成新的user mapper xml
- <mappers>
- <!--将操作配置文件系添加进mapper-->
- <mapper resource="mybatis/User2Mapper.xml" />
- </mappers>
3.准备实体类
同方式一
4.准备mapper接口(这个是比方式一多出来的)
- import com.mvc.User;
- // 这边接口名要和xml映射的文件名一致
- public interface User2Mapper {
- int insertUser(User user);
- // 其它方法略。。。
- }
5.准备实体对应的mapper映射xml文件
同方式一,只是namespace需要注意
- <?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一定要写完整正确 -->
- <mapper namespace="com.mybatis.mapper.User2Mapper">
- <!-- 通过id查询用户 -->
- <select id="findUserById" parameterType="int" resultType="com.mvc.User">
- select * from user where id = #{id}
- </select>
- <!--通过name查找一个list的用户,模糊匹配-->
- <select id="findUserByName" parameterType="java.lang.String" resultType="com.mvc.User">
- select * from user where name like '%${value}%'
- </select>
- <!--插入用户信息-->
- <insert id="insertUser" parameterType="com.mvc.User">
- <selectKey keyProperty="id" order="BEFORE" resultType="java.lang.String">
- select uuid()
- <!-- 这里是对于主键属性的id进行赋值 -->
- </selectKey>
- insert into user(id,username,password) values(#{id},#{username},#{password})
- </insert>
- <!--删除用户信息-->
- <delete id="deleteUser" parameterType="java.lang.Integer">
- delete from user where id=#{id}
- </delete>
- <!--更新用户信息-->
- <update id="updateUser" parameterType="com.mvc.User">
- update user set name=#{name},password=#{password} where id=#{id}
- </update>
- </mapper>
6.准备一个获取sqlsession的工具类
同方式一
7.准备dao
- import org.apache.ibatis.session.SqlSession;
- import com.mvc.User;
- import com.mybatis.mapper.User2Mapper;
- public class UserDao {
- SqlSession session = MybatisSessionUtil.getSession();
- // 使用接口方式
- public int insert2(User user){
- User2Mapper user2Mapper = session.getMapper(User2Mapper.class);
- int rint = user2Mapper.insertUser(user);
- session.commit();
- return rint;
- }
- }
8.测试类
- import com.mvc.User;
- import com.mybatis.util.UserDao;
- public class MybatisNoSpringTest {
- public static void main(String[] args) {
- UserDao userDao = new UserDao();
- User user = new User();
- user.setUsername("wwwttt");
- user.setPassword("33333");
- // 使用mapper接口方式
- if (userDao.insert2(user) == 1) {
- System.out.println("insert success...");
- }else{
- System.out.println("insert fail...");
- }
- }
- }
方式三:使用mybatis框架的注解编写sql
这种方式,我不推荐使用,本来我们使用mybatis就是为了sql编写和java代码能分开解耦,有更大的灵活性,使用这种方式反而不好。
另外,myatis官方也不推荐这种方式,官方说了,要想使用mybatis强大的sql编写功能,写在注解里是受到限制的,只有写在mapper xml里才能发挥的玲离尽致。
所以,这种方法我就不记录了,有需要的同学自行百度。
Mybatis(五):Mybatis的三种使用方式的更多相关文章
- Could not find resource mybatis.xml 找不到mybatis主配置文件的三种解决方式
第一种:先清除target目录 再重新compile编译 第二种:让idea重构项目 第三种 :手动添加到target目录下的classes包下
- MyBatis模糊查询的三种拼接方式
1. sql中字符串拼接 SELECT * FROM tableName WHERE name LIKE CONCAT(CONCAT('%', #{text}), '%'); 2. 使用 ${...} ...
- Spring Boot将Mybatis返回结果转为驼峰的三种实现方式
本文不再更新,可能存在内容过时的情况,实时更新请访问原地址:Spring Boot将Mybatis返回结果转为驼峰的三种实现方式: 我们通常获取Mybatis返回的数据结果时想要将字段以驼峰的形式返回 ...
- tomcat下jndi的三种配置方式
jndi(Java Naming and Directory Interface,Java命名和目录接口)是一组在Java应用中访问命名和目录服务的API.命名服务将名称和对象联系起来,使得我们可以用 ...
- 【转】tomcat下jndi的三种配置方式
jndi(Java Naming and Directory Interface,Java命名和目录接口)是一组在Java应用中访问命名和目录服务的API.命名服务将名称和对象联系起来,使得我们可以用 ...
- Map三种遍历方式
Map三种遍历方式 package decorator; import java.util.Collection; import java.util.HashMap; import java.util ...
- Service组件 总结 + 绑定理Service三种实现方式 Messager + Binder + AIDL
在Android中进程按优先级可以分为五类,优先级从高到低排列: - 前台进程 该进程包含正在与用户进行交互的界面组件,比如一个Activity - 可视进程 该进程中的组件虽然没有和用户交互,但是仍 ...
- C# 三种打印方式含代码
一:C#代码直接打印pdf文件(打印质保书pdf文件) 引用: 代码注释很详细了. private void btn_pdf_Click(object sender, RoutedEventArgs ...
- Hive的三种Join方式
Hive的三种Join方式 hive Hive中就是把Map,Reduce的Join拿过来,通过SQL来表示. 参考链接:https://cwiki.apache.org/confluence/dis ...
- python笔记-20 django进阶 (model与form、modelform对比,三种ajax方式的对比,随机验证码,kindeditor)
一.model深入 1.model的功能 1.1 创建数据库表 1.2 操作数据库表 1.3 数据库的增删改查操作 2.创建数据库表的单表操作 2.1 定义表对象 class xxx(models.M ...
随机推荐
- Android电话拨打权限绕过漏洞(CVE-2013-6272)分析
原文:http://blogs.360.cn/360mobile/2014/07/08/cve-2013-6272/ 1. CVE-2013-6272漏洞背景 CVE-2013-6272是一个安卓平台 ...
- Jquery 获取table当前行内容
$("a[name='checkOriginal']").click(function () { var parent = $(this).parent().parent().fi ...
- Linux随笔(安装ftp,安装jdk,安装 tomcat,安装redis,安装MySQL,安装svn)
su: authentication failure 解决办法:sudo passwd root 更改密码即可 确认虚拟机用到的联网方式是桥接模式,不然Windows是ping不通Linux的,确保 ...
- 【图解】javaScript组成结构
- spring mvc返回jsonp内容
代码如下: import com.alibaba.fastjson.JSONPObject; @RequestMapping(value = "/method1") @Respon ...
- 转:Gerrit 学习
转载:http://www.scmeye.com/thread-1665-1-1.html 入门Gerrit简介Gerrit是一个建立在Git版本控制系统之上,基于Web的代码审查工具,但如果你已经阅 ...
- mac 连接windows 共享内容
mac 连接windows 共享内容 一:场景 在win7上下载了一个5G左右的系统文件,想弄到mac上,本打算用使用U盘,把文件从win7copy到mac电脑上: 可是U盘的分区是fat的,大于4G ...
- Java从零开始学三十八(JAVA IO- 重定向IO)
一.三个静态变量 java.lang.System提供了三个静态变量 System.in(默认键盘) System.out(默认显示器) System.err 二.重写向方法 System提供了三个重 ...
- Closing a window
The obvious way to how to close a window is to click on the x mark on the titlebar. In the next exam ...
- 使用轻量级JAVA 爬虫Gecco工具抓取新闻DEMO
写在前面 最近看到Gecoo爬虫工具,感觉比较简单好用,所有写个DEMO测试一下,抓取网站 http://zj.zjol.com.cn/home.html,主要抓取新闻的标题和发布时间做为抓取测试对象 ...