MyBaties --day1
今天就来聊聊这个东西 今天的主角相信大家也看到了 MyBaties 是个什么东东 它有什么作用?怎么用?好不好用今天来说说 .说到MyBaties 就不得不谈到JDBC大家可能都知道 JDBC用来操作数据库 几乎所有的项目都会跟数据库进行交互 我们传统的JDBC访问数据主要为以下几部
- 通过Class.forName()加载驱动程序
- 通过DriverManage.getConnection()获取数据库连接
- 通过Connection.createStatement()或者preparedStatement()创建操作数据库的语句对象
- 执行SQL语句
- 处理SQL语句
- 关闭资源
弊端
- 他将数据库连接的信息都写在了java代码中 不便于数据源的切换
- 频繁的创建销毁数据连接 影响了程序的性能
- java源码中出现了大量的SQL语句 不便于修改SQL
- 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的更多相关文章
- NOIp2016 Day1&Day2 解题报告
Day1 T1 toy 本题考查你会不会编程. //toy //by Cydiater //2016.11.19 #include <iostream> #include <cstd ...
- day1
day1.py ][][: ][: ): : ]['lock'] = 0 json.dump(userlist_message, open(userlist, 'w')) break #输错次数到3次 ...
- myBaties 和 mysql开发中遇到的问题
最近开发内部平台遇到mysql 中的一个问题,order by语句需要在limit 之后. myBaties在parameterType="java.lang.String" 不能 ...
- day1作业--登录入口
作业概述: 编写一个登录入口,实现如下功能: (1)输入用户名和密码 (2)认证成功后显示欢迎信息 (3)输错三次后锁定 流程图: readme: 1.程序配置文件: 黑名单文件blacklist.t ...
- luogu1003铺地毯[noip2011 提高组 Day1 T1]
题目描述 为了准备一个独特的颁奖典礼,组织者在会场的一片矩形区域(可看做是平面直角坐标系的第一象限)铺上一些矩形地毯.一共有 n 张地毯,编号从 1 到n .现在将这些地毯按照编号从小到大的顺序平行于 ...
- mybaties # , $
mybaties会对#引入的值加上双引号, 如: #{buildingName} -------->"buildingName";mybaties会将$引入的值直接显示到sq ...
- springMVC 缓存(入门 spring+mybaties+redis一)
使用redis之前需要咋电脑上安装redis: 使用spring+mybaties+redis的本质是扩展类 org.apache.ibatis.cache.Cache:在我们自己扩展的Cache ...
- mybaties 的一些点
resultMap resutType mybaties缓存 待续 mybaties对应关系是bean和数据库字段的对应. 1.mybaties 的返回值是对象的话定义为resultMap=" ...
- Python学习路程day1
变量起名: 变量名如果太长,推荐使用下划线来分开,让人看得清晰明白.例:nums_of_alex_girl=19 .或者是驼峰写法,即首字母大写.例:NumOfAlexGf=18 注意:不合法的变量起 ...
随机推荐
- Linux下通过shell进MySQL执行SQL或导入脚本
这条命令表示通过用户名和密码执行shell然后在shell里面执行一个建表语句: USER="root" PASS="root" mysql -u $USER ...
- Scapy 从入门到放弃
0x00 前言 最近闲的没事,抽空了解下地表最强的嗅探和收发包的工具:scapy.scapy是一个python模块,使用简单,并且能灵活地构造各种数据包,是进行网络安全审计的好帮手. 0x01 安装 ...
- ubuntu的sudo免密
ubuntu的sudo免密与centos大同小异,都是在/etc/sudoers中添加用户信息,添加的内容也一样,只是位置不一样. centos的位置如下: 而ubuntu的位置如下: 除此之外,两行 ...
- java23种设计模式之九: 抽象工厂方法模式
一.抽象工厂定义 上一讲我们说了一下工厂方法,那么我们如何对工厂进行抽象. 因为工厂是生产产品的,现在我们需要工厂抽象,只生产抽象产品,不生产具体的产品,这同时也体现了java的多态. 现在有2个抽象 ...
- Markdown 空格详细介绍
它叫不换行空格,全称No-Break Space,它是最常见和我们使用最多的空格,大多数的人可能只接触了 ,它是按下space键产生的空格.在HTML中,如果你用空格键产生此空格,空格是不会累加的 ...
- Linux下使用Vim粘贴文本错乱问题解决
在使用vim进行文档操作时,经常需要进行复制粘贴,在粘贴大量代码时,出现行错位等各种错乱,查找问题解决办法: vim进入文件后,先ESC 在出入 :set paste 回车后再按下 i 之后进行粘 ...
- 剑指offer15:反转链表后,输出新链表的表头。
1 题目描述 输入一个链表,反转链表后,输出新链表的表头. 2 思路和方法 (1)利用栈作为中间存储,进行链表的反转,将压入的数据按先进后出的顺序弹出依次赋给链表再输出表头pHead. (2)将当前节 ...
- python可变类型与不可变类型
一.可变类型与不可变类型的特点 1.不可变数据类型 不可变数据类型在第一次声明赋值声明的时候, 会在内存中开辟一块空间, 用来存放这个变量被赋的值, 而这个变量实际上存储的, 并不是被赋予的这个值, ...
- 解析spring启动加载dubbo过程
一:简单配置 web.xml <context-param> <param-name>contextConfigLocation</param-name> < ...
- AtCoder Grand Contest 040 A - ><
传送门 对于某个位置,只要知道这个位置往左最多的连续 $\text{<}$ 的数量 $x$ 和往右最多的连续 $\text{>}$ 的数量 $y$ 那么这个位置最小可能的数即为 $max( ...