今天就来聊聊这个东西 今天的主角相信大家也看到了 MyBaties  是个什么东东 它有什么作用?怎么用?好不好用今天来说说 .说到MyBaties 就不得不谈到JDBC大家可能都知道 JDBC用来操作数据库 几乎所有的项目都会跟数据库进行交互 我们传统的JDBC访问数据主要为以下几部

  1. 通过Class.forName()加载驱动程序
  2. 通过DriverManage.getConnection()获取数据库连接
  3. 通过Connection.createStatement()或者preparedStatement()创建操作数据库的语句对象
  4. 执行SQL语句
  5. 处理SQL语句
  6. 关闭资源

弊端

  1. 他将数据库连接的信息都写在了java代码中 不便于数据源的切换
  2. 频繁的创建销毁数据连接 影响了程序的性能
  3. java源码中出现了大量的SQL语句 不便于修改SQL
  4. java对象模型与数据库关系不兼容 jdbc操作数据库时存在大量的实体对象与数据库关系之间相互转换的代码 可维护性差

这时MyBaties就出现了 MyBaties是基于JDBC的持久化层框架 它对jdbc操作数据库进行了封装 我们不需要花费时间区关注如何区处理注册驱动、创建连接 创建语句对象 以及对象与数据库关系的转化之间繁琐的代码,只需要关注SQL本身 而且不需要将SQL写在源码中 直接写在XML配置文件中 是不是很神奇呢?

那么如何去使用MyBaties

1.创建java项目

2.添加相关联的依赖包

3.添加MyBaties的核心配置文件

4.创建数据库 表以及实体类

5.添加MyBaties映射文件

6.创建SqlSessionFactory对象 SqlSession对象

下载MyBaties的地址网上一搜就可以找到  https://github.com/mybatis/mybatis-3/releases

解压后会发现里面有很多jar包我们可以选择部分添加到项目中 只需要这几个就够了 现在

log4j-1.2.17.jar     这个jar包是一个java日志文件夹包
mybatis-3.5.1.jar  使用MyBateis时必用的架包  
mysql-connector-java-5.1.47.jar 用来连接数据库
slf4j-api-1.7.26.jar     简单日记门面
slf4j-log4j12-1.7.26.jar

3.添加MyBaties核心配置文件 这里主要是 配置数据库的连接信息和 关联映射的文件

添加日志组件log4j的配置文件log4j.propertis至classpath根目录下,用于输出MyBatis执行过程中的日志信息。这里的

com/newroad/dao/StudentMapper.xml 是StudentMapper.xml文件的路径不能写错了
   <!-- 关联隐射文件 -->
<mappers>
<mapper resource="com/newroad/dao/StudentMapper.xml"/>
</mappers>

 <?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>
<!-- 配置环境信息,即数据源信息 -->
<environments default="d1">
<environment id="d1">
<!-- 配置事务管理器 -->
<transactionManager type="JDBC" />
<!-- 配置数据源以及数据库连接信息 -->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/fresh?characterEncoding=UTF-8" />
<property name="username" value="root" />
<property name="password" value="root" />
</dataSource>
</environment>
</environments> <!-- 关联隐射文件 -->
<mappers>
<mapper resource="com/newroad/dao/StudentMapper.xml"/>
</mappers> </configuration>

4.创建数据库、表以及实体类

package com.newroad.entity;

public class Student {

    private Integer id;
private String name;
private String password;
private String email; @Override
public String toString() {
return "Student [id=" + id + ", name=" + name + ", password=" + password + ", email=" + email + "]";
} public Student(Integer id, String name, String password, String email) {
super();
this.id = id;
this.name = name;
this.password = password;
this.email = email;
} public Integer getId() {
return id;
} public void setId(Integer id) {
this.id = id;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public String getPassword() {
return password;
} public void setPassword(String password) {
this.password = password;
} public String getEmail() {
return email;
} public void setEmail(String email) {
this.email = email;
} }

5.创建StudentMapper.xml 的映射文件 MyBatis映射文件是一个XML文件,在这个XML文件中可以 我们可以写要执行的SQL语句

 3 <!-- namespace必須属性 使用mybaties时通过namespace的值找到 Mapper文件 -->
4 <mapper namespace="com.newroad.dao.StudentMapper"> 这一步很重要 是一个必须的属性
 <?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必須属性 使用mybaties时通过namespace的值找到 Mapper文件 -->
<mapper namespace="com.newroad.dao.StudentMapper">
<!-- 添加用户信息 -->
<insert id="save">
insert into student(id,name,password,email) values (#{id},#{name},#{password},#{email})
</insert> <!-- 删除学生信息通过ID -->
<delete id="deleteById" >
delete from student where id=#{id}
</delete> <!-- 修改学生信息 -->
<update id="updateById">
update student set name=#{name},password=#{password},email=#{email} where id=#{id}
</update>
<!-- 查询学生信息 -->
<!-- 根据学号查询学生信息 -->
<!-- resultType | resultMap 这两个属性必须二选一 指的是将查询到的数据转换成怎样的pojo对象 -->
<select id="selectByid" resultType="com.newroad.entity.Student">
select *from student where id=#{id} </select> <!-- 查询所有学生信息 -->
<select id="selectAll" resultType="com.newroad.entity.Student">
select *from student </select> <!--分页查询 -->
<select id="selectByPages" resultType="com.newroad.entity.Student">
select *from student limit #{pageNum},#{pageSize}
</select> </mapper>

6.创建SqlSessionFactory、SqlSession对象

注意:   int num = session.insert("com.newroad.dao.StudentMapper.save", stu);

这里的 com.newroad.dao.StudentMapper 对应着StudentMapper.xml映射文件中的 namespace的值 而后面的save 对应id的名字一定要相同

 package com.newroad.test;

 import static org.junit.Assert.assertEquals;
import java.io.InputStream;
import java.util.List;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.After;
import org.junit.Before; import org.junit.Test; import com.newroad.entity.Student; public class Test2 {
// 获取连接配置对象
InputStream in = Test2.class.getResourceAsStream("/mybatis-config.xml");
// 创建sqlsessionFactoryBuilder
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
SqlSessionFactory factory = builder.build(in);
SqlSession session; @Before // 在每个test方法执行之前都会执行这个方法
public void init() {
session = factory.openSession();
} @Test // 测试的方法
public void test() {
Student stu = new Student(12, "pan", "10086", "123432@qq.com");
int num = session.insert("com.newroad.dao.StudentMapper.save", stu);
// 断言结果 如果结果为1 成功
assertEquals(num, 1); } @Test
public void deleteById() {
int num = session.delete("com.newroad.dao.StudentMapper.deleteById", 6);
System.out.println("num=" + num);
assertEquals(num, 1);
} @Test
public void selectOne() {
Student stu = session.selectOne("com.newroad.dao.StudentMapper.selectByid", 4);
System.out.println("num=" + stu);
assertEquals(stu, 1);
} @Test
public void listStudent() {
List<Student> students = session.selectList("com.newroad.dao.StudentMapper.selectAll");
students.forEach(stu -> System.out.println(stu)); } @After // 在每个test方法执行后就会执行
public void close() {
session.commit();
session.close();
} }
 

MyBaties --day1的更多相关文章

  1. NOIp2016 Day1&Day2 解题报告

    Day1 T1 toy 本题考查你会不会编程. //toy //by Cydiater //2016.11.19 #include <iostream> #include <cstd ...

  2. day1

    day1.py ][][: ][: ): : ]['lock'] = 0 json.dump(userlist_message, open(userlist, 'w')) break #输错次数到3次 ...

  3. myBaties 和 mysql开发中遇到的问题

    最近开发内部平台遇到mysql 中的一个问题,order by语句需要在limit 之后. myBaties在parameterType="java.lang.String" 不能 ...

  4. day1作业--登录入口

    作业概述: 编写一个登录入口,实现如下功能: (1)输入用户名和密码 (2)认证成功后显示欢迎信息 (3)输错三次后锁定 流程图: readme: 1.程序配置文件: 黑名单文件blacklist.t ...

  5. luogu1003铺地毯[noip2011 提高组 Day1 T1]

    题目描述 为了准备一个独特的颁奖典礼,组织者在会场的一片矩形区域(可看做是平面直角坐标系的第一象限)铺上一些矩形地毯.一共有 n 张地毯,编号从 1 到n .现在将这些地毯按照编号从小到大的顺序平行于 ...

  6. mybaties # , $

    mybaties会对#引入的值加上双引号, 如: #{buildingName} -------->"buildingName";mybaties会将$引入的值直接显示到sq ...

  7. springMVC 缓存(入门 spring+mybaties+redis一)

    使用redis之前需要咋电脑上安装redis: 使用spring+mybaties+redis的本质是扩展类   org.apache.ibatis.cache.Cache:在我们自己扩展的Cache ...

  8. mybaties 的一些点

    resultMap resutType mybaties缓存 待续 mybaties对应关系是bean和数据库字段的对应. 1.mybaties 的返回值是对象的话定义为resultMap=" ...

  9. Python学习路程day1

    变量起名: 变量名如果太长,推荐使用下划线来分开,让人看得清晰明白.例:nums_of_alex_girl=19 .或者是驼峰写法,即首字母大写.例:NumOfAlexGf=18 注意:不合法的变量起 ...

随机推荐

  1. Release报错Debug无错

    代码在Release模式下会crash,Debug模式下可以运行,最后定位到原因 for (size_t j = 0; j < ids.size()-1; ++j) { } 发现问题是Relea ...

  2. .Net Core 定时器Quartz

    最近因为项目需要用到了Quartz,下面简单记录一下. 一.首先需要安装Quartz. 二.定义一个执行的Job类,实现IJob接口,接口有一个方法Execute,用来执行定时任务的实现内容. pub ...

  3. 《C语言程序设计》学习笔记(二)

    第八章 函数 函数的基本概念 定义:函数由函数名.参数和函数体组成. 函数定义的一般形式: 类型说明符 函数名(形式参数声明) { [说明与定义部分] 语句: } 说明: 1.类型说明符用来说明函数的 ...

  4. markdown语法(测试自用)

    Markdown语法主要分为几大部分:标题.段落.区块引用.代码区块.强调.列表.分割线.链接.图片.反斜杠.符号'`' 1.标题 两种形式 1)使用 = 和 - 标记一级标题和二级标题 一级标题 二 ...

  5. 遇到引入的JS不起作用

    1.js的加载是有先后顺序的,并且不能重复引入,重复引入的只有最后一个起作用 2.在使用ligerUI的时候一定要先引用jQuery再引用ligerUI 3.在使用jQuery时遇到变量名未定义的主要 ...

  6. 日常工作问题解决:rhel7下配置多路径设备

    目录 1.情景描述 2.安装多路径软件 2.1 安装多路径 2.2检查安装情况 2.3 重启系统 2.4 将多路径软件添加至内核模块 2.5 检查内核添加情况 2.6 启动multipath服务 2. ...

  7. [转帖]使用TOAD优化复杂SQL

    独家秘笈!看下如何一键优化Oracle数据库复杂sql,DBA必备 https://www.toutiao.com/i6741208493644055053/ 原来toad 还有这种功能 感觉类似于 ...

  8. 剑指offer60:把二叉树打印成多行。上到下按层打印二叉树。

    1 题目描述 从上到下按层打印二叉树,同一层结点从左至右输出.每一层输出一行. 2 思路和方法 vector变量存储每一层的元素vector<vector<int> > ans ...

  9. Excel逻辑运算函数

    Excel逻辑运算函数 1.FALSE和TRUE的使用 ​ 筛选出表中salary>6.gender为男.age>28至少满足这三个条件中的两个的数据 1.依次使用:=C2>6.=D ...

  10. 变量————if语句——结构使用

    1简述变量的命名规范 变量是以字母 数字 下划线组合而成 不能以数字开头 不能使用python中的关键字命名 变量要具有可描述性 区分大小写 name变量是什么数据类型通过代码检测 name = in ...