注意,这篇文章只介绍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的三种使用方式的更多相关文章

  1. Could not find resource mybatis.xml 找不到mybatis主配置文件的三种解决方式

    第一种:先清除target目录 再重新compile编译 第二种:让idea重构项目 第三种 :手动添加到target目录下的classes包下

  2. MyBatis模糊查询的三种拼接方式

    1. sql中字符串拼接 SELECT * FROM tableName WHERE name LIKE CONCAT(CONCAT('%', #{text}), '%'); 2. 使用 ${...} ...

  3. Spring Boot将Mybatis返回结果转为驼峰的三种实现方式

    本文不再更新,可能存在内容过时的情况,实时更新请访问原地址:Spring Boot将Mybatis返回结果转为驼峰的三种实现方式: 我们通常获取Mybatis返回的数据结果时想要将字段以驼峰的形式返回 ...

  4. tomcat下jndi的三种配置方式

    jndi(Java Naming and Directory Interface,Java命名和目录接口)是一组在Java应用中访问命名和目录服务的API.命名服务将名称和对象联系起来,使得我们可以用 ...

  5. 【转】tomcat下jndi的三种配置方式

    jndi(Java Naming and Directory Interface,Java命名和目录接口)是一组在Java应用中访问命名和目录服务的API.命名服务将名称和对象联系起来,使得我们可以用 ...

  6. Map三种遍历方式

    Map三种遍历方式 package decorator; import java.util.Collection; import java.util.HashMap; import java.util ...

  7. Service组件 总结 + 绑定理Service三种实现方式 Messager + Binder + AIDL

    在Android中进程按优先级可以分为五类,优先级从高到低排列: - 前台进程 该进程包含正在与用户进行交互的界面组件,比如一个Activity - 可视进程 该进程中的组件虽然没有和用户交互,但是仍 ...

  8. C# 三种打印方式含代码

    一:C#代码直接打印pdf文件(打印质保书pdf文件) 引用: 代码注释很详细了. private void btn_pdf_Click(object sender, RoutedEventArgs ...

  9. Hive的三种Join方式

    Hive的三种Join方式 hive Hive中就是把Map,Reduce的Join拿过来,通过SQL来表示. 参考链接:https://cwiki.apache.org/confluence/dis ...

  10. python笔记-20 django进阶 (model与form、modelform对比,三种ajax方式的对比,随机验证码,kindeditor)

    一.model深入 1.model的功能 1.1 创建数据库表 1.2 操作数据库表 1.3 数据库的增删改查操作 2.创建数据库表的单表操作 2.1 定义表对象 class xxx(models.M ...

随机推荐

  1. 2014年ENVI/IDL遥感应用与开发培训班-11月重庆站 開始报名了

    主办单位: 中国遥感应用协会 Esri中国信息技术有限公司 内容简单介绍: 依据中国遥感应用协会栾恩杰理事长推动国内遥感技术和应用的指示精神,2014年中国遥感应用协会组织培训交流部与Esri中国信息 ...

  2. 【Nodejs】理想论坛帖子下载爬虫1.04

    一直想做一个能把理想论坛指定页范围的帖子都能完整下载下来的爬虫,但未能如愿. 主要的障碍在并发数的控制和长时间任务的突然退出,比如想下载前五页的帖子,分析后可得到大约15000个主贴或子贴,如果用回调 ...

  3. hbase-0.94安装方法具体解释

    先决条件:     1)java环境,须要安装java1.6以上版本号     2)hadoop环境.因为HBase架构是基于其它文件存储系统的,因此在分布式模式下安装Hadoop是必须的,可是,假设 ...

  4. Discuz常见小问题-如何快速安装和配置

    下载PHPNOW 可以解压到本地的某个目录,最好不要有中文路径,然后查看Readme进行安装,双击Setup.cmd 安装结束之后,会要求输入一个初始化的密码,不要忘记,会自动弹出一个测试页面,可以测 ...

  5. Subversion快速入门教程

    如何快速建立Subversion服务器,并且在项目中使用起来,这是大家最关心的问题,与CVS相比,Subversion有更多的选择,也更加的容易,几个命令就可以建立一套服务器环境,可以使用起来,这里配 ...

  6. IOS 将公历日期转换为中国农历

    代码方法: //日期阳历转换为农历: - (NSString *)convertDateToNongLi:(NSString *)aStrDate { NSDate *dateTemp = nil; ...

  7. Linux文件类型(学习笔记六)

    一.Linux下的文件类型 普通文件:在由 ls –al 所显示出来的属性方面,第一个属性为 [ - ] 目录文件:在由 ls –al 所显示出来的属性方面,第一个属性为 [ d ] 设备文件:一般都 ...

  8. 使用JSP实现输出(web基础学习笔记二)

    Jsp:Java Server Page 服务器端的Java页面,动态网页技术 jsp注释 显式注释:这种注释客户端是允许看见的;<!--html注释--> 隐式注释:这种注释客户端是看不 ...

  9. 算法笔记_168:历届试题 矩阵翻硬币(Java)

    目录 1 问题描述 2 解决方案   1 问题描述 问题描述 小明先把硬币摆成了一个 n 行 m 列的矩阵. 随后,小明对每一个硬币分别进行一次 Q 操作. 对第x行第y列的硬币进行 Q 操作的定义: ...

  10. 参数关键点和return返回多个(伪多个)值问题

    # -*- coding: cp936 -*- #python 27 #xiaodeng #参数关键点和return返回多个(伪多个)值问题 #传递参数的概念: #即:对象作为输入,发送给函数的方式 ...