Mybatis概述

定义: Mybatis是一个支持普通sql查询,存储过程和高级映射的优秀持久层框架。

  • Mybatis是(半自动的)跟数据库打交道的orm(object relationship mapping 对象 关系 映射)框架.
  • MyBatis 是一个优秀的基于 Java 的持久层框架,它内部封装了 JDBC(Java数据库连接),使开发者只需关注 SQL 语句本身,而不用再花费精力去处理诸如注册驱动、创建 Connection、配置 Statement 等繁杂过程。

对框架的粗浅理解

框架作用:解耦,即降低耦合度,减少开发时间(偷懒)的东西,但是并不代表框架的运行速度很高。以下两个原则是框架的重要思想。

重构原则:事不过三,三则重构(有三个地方代码重复)

  • “高内聚低耦合”做法:

    • 写且只写一次
    • 一个类只做一种事
    • 一个方法只做一件事

Mybatis的特点

  • Sql语句写在XML文件中,实现了代码与Sql分离,降低耦合度
  • 半自动的mybatis更利于开发人员设计Sql语句
  • 简单易学
  • 支持动态Sql

Mybatis配置和初步使用

Mybatis通过dao层与数据交互

1.pom.xml导入相应依赖

  <!-- mybatis核心包 -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.3.0</version>
</dependency>
<!-- mysql驱动包 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.40</version>
</dependency>

Maven要按照大佬博客说的配置,接下来file-->settings-->Maven-->Maven home directory设置为Maven安装包路径

然后user settings file 设置为安装包路径\conf\settings.xml,否则导依赖失败

2.mybatis核心配置mybatis-config.xml

<?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>
<properties resource="mysql.properties"/> <settings>
<!--全局性设置懒加载。如果设为‘false’,则所有相关联的都会被初始化加载,默认值为false-->
<setting name="lazyLoadingEnabled" value="true"/>
<!--当设置为‘true’的时候,懒加载的对象可能被任何懒属性全部加载。否则,每个属性都按需加载。默认值为true-->
<setting name="aggressiveLazyLoading" value="false"/>
</settings>
<typeAliases>
<!-- 其实就是将bean的替换成一个短的名字-->
<typeAlias type="com.qf.pojo.User" alias="User"/>
</typeAliases>
<!--对事务的管理和连接池的配置-->
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"></transactionManager>
<dataSource type="POOLED"><!--POOLED:使用Mybatis自带的数据库连接池来管理数据库连接-->
<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>
<!--mapping文件路径配置-->
<mappers>
<mapper resource="mapper/UserMapper.xml"/>
</mappers> </configuration>

3.配置mysql.properties

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://127.0.0.1:3306/demo1?useUnicode=true&characterEncoding=utf8&characterSetResults=utf8
jdbc.username=root
jdbc.password=123456

其中?useUnicode=true&characterEncoding=utf8&characterSetResults=utf8是为了防止乱码而加的

4.配置映射文件,以下有增删改查sql语句

<?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="com.qf.mybatisdemo.pojo.User"> <!--部分查询->
<select id="getUserByName" resultType="com.qf.mybatisdemo.pojo.User" parameterType="java.lang.String">
SELECT * FROM USER where username = #{username}
</select> <insert id="addUser" parameterType="com.qf.mybatisdemo.pojo.User" >
insert into USER(username,age) values(#{username},#{age})
</insert> <update id="updateUserAge" parameterType="com.qf.mybatisdemo.pojo.User">
update user set age=#{age} where username=#{username}
</update> <delete id="deleUser" parameterType="com.qf.mybatisdemo.pojo.User">
delete from user where username=#{username} and age=#{age}
</delete>
</mapper>

5.创建与数据库表的字段对应的实体类

package com.qf.mybatisdemo.pojo;

public class User {
String username;
int age; public String getUsername() {
return username;
} public void setUsername(String username) {
this.username = username;
} public int getAge() {
return age;
} public void setAge(int age) {
this.age = age;
} @Override
public String toString() {
return "User{" +
"username='" + username + '\'' +
", age=" + age +
'}';
}
}

6.创建会话(dao层与数据库交互数据的介质)接口

package com.qf.mybatisdemo.dao;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder; import java.io.IOException;
import java.io.Reader; public class BaseDao {
public SqlSession getSqlSession() {
String fileName = "mybatis-config.xml";
Reader reader = null;
try {
reader = Resources.getResourceAsReader(fileName);
} catch (IOException e) {
e.printStackTrace();
}
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
SqlSession sqlSession = sqlSessionFactory.openSession();
return sqlSession;
}
}

7.增删改查接口

package com.qf.mybatisdemo.dao;

import com.qf.mybatisdemo.pojo.User;
import org.apache.ibatis.session.SqlSession; import java.util.List; public class UserDao extends BaseDao{
User user; /**
* 根据名字查询
*/
public User getUserByName(String userName) {
SqlSession sqlSession = this.getSqlSession();
user = sqlSession.selectOne("getUserByName",userName);
return user;
} /**
* 增
*/
public int addUser(User user) {
int count = 0;
SqlSession sqlSession = this.getSqlSession();
count = sqlSession.insert("addUser",user);
sqlSession.commit();
return count;
} /**
* 改
*/
public int updateUserAge(User user) {
int count= 0;
SqlSession sqlSession = this.getSqlSession();
count = sqlSession.update("updateUserAge",user);
sqlSession.commit();
return count;
} /**
* 删除
*/
public int deleUser(User user) {
int count= 0;
SqlSession sqlSession = this.getSqlSession();
count = sqlSession.update("deleUser",user);
sqlSession.commit();
return count;
}
}

8.测试类

package com.qf.mybatisdemo;

import com.qf.mybatisdemo.dao.UserDao;
import com.qf.mybatisdemo.pojo.User;
import org.junit.Test; import javax.jws.soap.SOAPBinding; public class TestMybatis {
UserDao userDao;
/**
* 根据名字查询
*/
@Test
public void getUserByName () {
User user;
user = userDao.getUserByName("张三");
System.out.println(user);
} public static void main(String[] args) {
UserDao userDao = new UserDao(); /**
* 增
*/
// User user = new User();
// int count = 0;
// user.setAge(18);
// user.setUsername("小风");
// count = userDao.addUser(user);
// System.out.println(count); /**
* 改
*/
// User user = new User();
// int count = 0;
// user.setAge(20);
// user.setUsername("小风");
// count = userDao.updateUserAge(user);
// System.out.println("新的"+count); /**
* 删
*/
User user = new User();
int count = 0;
user.setAge(20);
user.setUsername("小风");
count = userDao.deleUser(user);
System.out.println(count);
}
}

(二)Mybatis总结之通过Dao层与数据交互的更多相关文章

  1. 关于mysql,需要掌握的基础(二):JDBC和DAO层

    ​ 目录 关于mysql,需要掌握的基础(二):JDBC和DAO层 1.了解jdbc是什么? 2.加载注册驱动:为什么Class.forName("com.mysql.jdbc.Driver ...

  2. SSM框架之Mybatis(3)dao层开发

    Mybatis(3)dao层开发 以实现类完成CRUD操作 1.持久层dao层接口的书写 src\main\java\dao\IUserDao.java package dao; import dom ...

  3. controller层负责创建类传递类给service;service层负责逻辑编写调用dao层 将编写后的类传递到dao层,保证事务的正确性;dao层负责数据的持久化

    controller层负责创建类传递类给service:service层负责逻辑编写调用dao层 将编写后的类传递到dao层,保证事务的正确性:dao层负责数据的持久化

  4. Java秒杀简单设计二:数据库表和Dao层设计

    Java秒杀简单设计二:数据库表Dao层设计 上一篇中搭建springboot项目环境和设计数据库表  https://www.cnblogs.com/taiguyiba/p/9791431.html ...

  5. mybatis mapper接口开发dao层

    本文将探讨使用 mapper接口,以及 pojo 包装类进行 dao 层基本开发 mybatis dao 层开发只写 mapper 接口 其中需要 开发的接口实现一些开发规范 1. UserMappe ...

  6. mybatis generator 自动生成dao层映射代码

    资源: doc url :http://www.mybatis.org/generator/ download:https://github.com/mybatis/generator/release ...

  7. Mybatis框架三:DAO层开发、Mapper动态代理开发

    这里是最基本的搭建:http://www.cnblogs.com/xuyiqing/p/8600888.html 接下来做到了简单的增删改查:http://www.cnblogs.com/xuyiqi ...

  8. 0 - Dao层(数据访问层设计)

    1. Dao 使用接口设计 2. Dao 没有实现代码, 使用模板实现(通过DynamicProxy+Dapper) 3. 模板格式暂定使用Ader Template 来自为知笔记(Wiz)

  9. MyBatis开发Dao层的两种方式(原始Dao层开发)

    本文将介绍使用框架mybatis开发原始Dao层来对一个对数据库进行增删改查的案例. Mapper动态代理开发Dao层请阅读我的下一篇博客:MyBatis开发Dao层的两种方式(Mapper动态代理方 ...

随机推荐

  1. 2017-10-02-afternoon

    T1 最大值(max) Time Limit:1000ms   Memory Limit:128MB 题目描述 LYK有一本书,上面有很多有趣的OI问题.今天LYK看到了这么一道题目: 这里有一个长度 ...

  2. 洛谷—— P2543 [AHOI2004]奇怪的字符串

    P2543 [AHOI2004]奇怪的字符串 题目描述 输入输出格式 输入格式: 输入文件中包含两个字符串X和Y.当中两字符串非0即1.序列长度均小于9999. 输出格式: X和Y的最长公共子序列长度 ...

  3. springboot 关于第三方包 打包问题

    第三方包: 添加library 依赖 在pom.xml中配置 <resources> <resource> <directory>lib</directory ...

  4. AndroidStudio NDK开发、调试测试工程

    ## 验证内容:1.支持NDK调试 2.支持native方法快速创建jni封装(但是没有加入extern "C"声明,会导致native方法找不到jni,进而报错) 3.支持通过修 ...

  5. pycharm支持react

    安装nodejs插件 使能node 出现下面的变化,在scope里可以定义使用的范围 创建react项目 使能eslint规则检查功能 配置前端启动脚本: https://www.jetbrains. ...

  6. hdu 5288 OO’s Sequence(2015 Multi-University Training Contest 1)

    OO's Sequence                                                          Time Limit: 4000/2000 MS (Jav ...

  7. 条款十七: 在operator=中检查给自己赋值的情况

    在赋值运算符中要特别注意可能出现别名的情况,其理由基于两点.其中之一是效率.如果可以在赋值运算符函数体的首部检测到是给自己赋值,就可以立即返回,从而可以节省大量的工作,否则必须去实现整个赋值操作. 另 ...

  8. [Unity3D]Unity3D游戏开发之从Unity3D到Eclipse

    ---------------------------------------------------------------------------------------------------- ...

  9. Java 编码 UTF-8

    近期在处理文件时发现了相同类型的文件使用的编码可能是不同的.所以想将文件的格式统一一下(由于UTF-8的通用性,决定往UTF-8统一),遇见的第一个问题是:怎样查看现有文件的编码方式. 文件编码问题集 ...

  10. cocos2dx 2.2.3编译第一个apk到安卓手机

    1.android-ndk-r10(注意32位和64位的别下错了 我不小心下错了 折腾了我两天) 2.adt_201407(eclipse已经跟sdk等等集成在一起了)   3.Cococs2d-x ...