Mybatis(五):Mybatis的三种使用方式

Stella981
• 阅读 400

注意,这篇文章只介绍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表

Mybatis(五):Mybatis的三种使用方式

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里才能发挥的玲离尽致。

所以,这种方法我就不记录了,有需要的同学自行百度。

点赞
收藏
评论区
推荐文章
浅梦一笑 浅梦一笑
4个月前
初学 Python 需要安装哪些软件?超级实用,小白必看!
编程这个东西是真的奇妙。对于懂得的人来说,会觉得这个工具是多么的好用、有趣,而对于小白来说,就如同大山一样。其实这个都可以理解,大家都是这样过来的。那么接下来就说一下python相关的东西吧,并说一下我对编程的理解。本人也是小白一名,如有不对的地方,还请各位大神指出01名词解释:如果在编程方面接触的比较少,那么对于软件这一块,有几个名词一定要了解,比如开发环
光头强的博客 光头强的博客
4个月前
Java面向对象试题
1、请创建一个Animal动物类,要求有方法eat()方法,方法输出一条语句“吃东西”。创建一个接口A,接口里有一个抽象方法fly()。创建一个Bird类继承Animal类并实现接口A里的方法输出一条有语句“鸟儿飞翔”,重写eat()方法输出一条语句“鸟儿吃虫”。在Test类中向上转型创建b对象,调用eat方法。然后向下转型调用eat()方
刚刚好 刚刚好
4个月前
css问题
1、在IOS中图片不显示(给图片加了圆角或者img没有父级)<div<imgsrc""/</divdiv{width:20px;height:20px;borderradius:20px;overflow:h
blmius blmius
1年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
小森森 小森森
4个月前
校园表白墙微信小程序V1.0 SayLove -基于微信云开发-一键快速搭建,开箱即用
后续会继续更新,敬请期待2.0全新版本欢迎添加左边的微信一起探讨!项目地址:(https://www.aliyun.com/activity/daily/bestoffer?userCodesskuuw5n)\2.Bug修复更新日历2.情侣脸功能大家不要使用了,现在阿里云的接口已经要收费了(土豪请随意),\\和注意
晴空闲云 晴空闲云
4个月前
css中box-sizing解放盒子实际宽高计算
我们知道传统的盒子模型,如果增加内边距padding和边框border,那么会撑大整个盒子,造成盒子的宽度不好计算,在实务中特别不方便。boxsizing可以设置盒模型的方式,可以很好的设置固定宽高的盒模型。盒子宽高计算假如我们设置如下盒子:宽度和高度均为200px,那么这会这个盒子实际的宽高就都是200px。但是当我们设置这个盒子的边框和内间距的时候,那
艾木酱 艾木酱
3个月前
快速入门|使用MemFire Cloud构建React Native应用程序
MemFireCloud是一款提供云数据库,用户可以创建云数据库,并对数据库进行管理,还可以对数据库进行备份操作。它还提供后端即服务,用户可以在1分钟内新建一个应用,使用自动生成的API和SDK,访问云数据库、对象存储、用户认证与授权等功能,可专
Wesley13 Wesley13
1年前
MySQL查询按照指定规则排序
1.按照指定(单个)字段排序selectfromtable_nameorderiddesc;2.按照指定(多个)字段排序selectfromtable_nameorderiddesc,statusdesc;3.按照指定字段和规则排序selec
Wesley13 Wesley13
1年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
helloworld_28799839 helloworld_28799839
4个月前
常用知识整理
Javascript判断对象是否为空jsObject.keys(myObject).length0经常使用的三元运算我们经常遇到处理表格列状态字段如status的时候可以用到vue