Mybatis实例增删改查(二)
创建实体类:
package com.test.mybatis.bean;
public class Employee {
private Integer id;
private String lastName;
private String email;
private String gender;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getLastName() {
return lastName;
}
public void setLastName(String lastName) {
this.lastName = lastName;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public String getGender() {
return gender;
}
public void setGender(String gender) {
this.gender = gender;
}
@Override
public String toString() {
return "Employee [id=" + id + ", lastName=" + lastName + ", email="
+ email + ", gender=" + gender + "]";
}
}
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>
<!--
1、mybatis可以使用properties来引入外部配置文件的内容
resource:引入类路径下的资源
url:引入网络路径或者磁盘路径下的资源
-->
<properties resource="jdbcconf.properties">
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
</properties>
<!--
2、settings包含很多的设置项
setting:用来设置每一个设置项
name:设置项名
value:设置项取值
-->
<settings>
<!--
驼峰命名规则:当数据库名与实体类名发生不一致时,驼峰命名则会发挥作用
如:
数据库字段:id stuname
实体类属性:id stuName
-->
<setting name="mapUnderscoreToCamelCase" value="true"/>
</settings>
<!--
3、typeAliases:别名处理器,可以为Java类型起别名
别名不区分大小写
-->
<typeAliases>
<!--
type:指定要起别名的类型全类名;默认别名就是类名小写:
alias:指定新的别名
-->
<!-- <typeAlias type="com.test.mybatis.Employee" alias="emp"/> -->
<!--
package:为某个包下的所有类批量起别名
也可在具体的实体类中使用@Alias注解为某个类型指定新的别名
-->
<package name="com.test.mybatis.bean"/>
</typeAliases>
<!-- 4、environments:配置环境,可配置多种环境(development,test)
environment:配置一个具体的环境信息,必须有两个标签;
id:代表当前环境的唯一标识
transactionManager:事务管理器
type:事务管理器的类型;JDBC\MANAGED
自定义事务管理:实现TransactionFactory接口,type指定为全类名
DataSource: 数据源
type: 数据源类型
UNPOOLED(UnpooledDataSourceFactory)
POOLED(PooledDataSourceFactory)
JNDI(JndiDataSourceFactory)
-->
<environments default="development">
<environment id="development">
<!-- 事务类型 -->
<transactionManager type="JDBC"/>
<!-- 数据源 -->
<dataSource type="POOLED">
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
</dataSource>
</environment>
</environments> <!--
5、databaseIdProvider:支持多数据库厂商
type="DB_VENDOR"
作用就是得到数据库厂商标识,mybatis就能根据不同的数据库厂商标识,执行不同的SQL语句
MySQL Oracle SQL Server
-->
<databaseIdProvider type="DB_VENDOR">
<!-- 为不同数据库厂商起别名 -->
<property name="MySQL" value="mysql"/>
<property name="Oracle" value="oracle"/>
<property name="SQL Server" value="sqlserver"/>
</databaseIdProvider>
<!-- 将我们写好的sql映射文件(EmployeeMapper.xml)一定要注册到 mybatis-config.xml中-->
<!-- 6、mappers:将sql映射注册到全局配置中 -->
<mappers>
<!--
`mapper:注册一个sql映射
注册配置文件
resource:引用类路径下的sql映射文件
url:引用网络路径或者磁盘路径下的sql映射文件
class:引用(注册)接口
1、必须有sql映射文件,映射文件名必须和接口同名,切放在与接口同一个目录下
2、没有sql映射,所有sql都是利用注解写在接口上(@Select() @Insert() @Update @Delete)
-->
<mapper resource="EmployeeMapper.xml"/>
<!-- <mapper class="com.test.mybatis.dao.EmployeeMapper.xml"/> -->
<!--
批量注册 :映射文件名必须和接口同名,且在同一个包下
-->
<!-- <package name="com.test.mybatis.dao"/> -->
</mappers> </configuration>
数据库信息的配置:
jdbc.properties
driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis
username=root
password=root
创建接口:
package com.test.mybatis.dao;
import com.test.mybatis.bean.Employee;
public interface EmployeeMapper {
public Employee getEmpById(Integer id);
public boolean addEmployee(Employee employee);
public boolean modifyEmployee(Employee employee);
public boolean removeEmployee(Integer id);
}
实现接口:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mtbatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.test.mybatis.dao.EmployeeMapper">
<!--
namespace:名称空间 指定为接口的全类名
id:唯一标识
resultType:返回值类型
#{id}:从传递过来的参数中去吃id值
databaseId:标识数据库执行环境
--> <!--
若此两种方法同时存在,则会默认使用带有数据库厂商标识的方法
若存在三种方法,则默认加载当前数据库环境下的带有厂商标识的方法和未带标识的方法
-->
<select id="getEmpById" resultType="employee">
select * from tbl_employee where id=#{id}
</select>
<select id="getEmpById" resultType="employee"
databaseId="mysql">
select * from tbl_employee where id=#{id}
</select>
<insert id="addEmployee" parameterType="employee">
insert into tbl_employee(email,last_name,gender) values(#{email},#{lastName},#{gender}) </insert>
<update id="modifyEmployee">
update tbl_employee
set
email=#{email},
last_name=#{lastName},
gender=#{gender}
where
id=#{id}
</update>
<delete id="removeEmployee">
delete from tbl_employee where id=#{id}
</delete>
</mapper>
测试:
package com.test.mybatis.test; import java.io.IOException;
import java.io.InputStream; 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 org.junit.Test; import com.test.mybatis.dao.EmployeeMapper; public class MyBatisTest {
//读取配置文件,得到SQLSessionFactory
public SqlSessionFactory getSqlSessionFactory() throws IOException{
String resource="mybatis-config.xml";
InputStream is=Resources.getResourceAsStream(resource);
return new SqlSessionFactoryBuilder().build(is);
}
@Test
public void test01() throws IOException{
//获取sqlSessionFactory对象
SqlSessionFactory sqlSessionFactory = getSqlSessionFactory();
//获取sqlSession
//代表和数据库的一次对话,用完必须关闭,相当于connection,都是非线程安全。每次使用都应该获取新的对象
SqlSession openSession = sqlSessionFactory.openSession();
try{
//获取接口的实现类对象
//会为接口自动的创建一个代理对象,代理对象去执行增删查改方法
//mapper接口没有实现类,但是mybatis会为这个接口生成一个代理对象
//(将接口和xml进行绑定)
EmployeeMapper mapper = openSession.getMapper(EmployeeMapper.class);
//查询操作
// Employee emp = mapper.getEmpById(1); //添加操作
// Employee employee=new Employee();
// employee.setEmail("6789@test.com");
// employee.setGender("2");
// employee.setLastName("test01");
// boolean flag = mapper.addEmployee(employee); //修改操作
// Employee emp=new Employee();
// emp.setLastName("tommer");
// emp.setId(6);
// boolean flag = mapper.modifyEmployee(emp); //删除操作,mybatis会根据所执行结果的影响行数,或者记录数,去确定返回值是否为true(影响行数或记录数>=1)\false(影响行数或记录数<1)
Boolean flag= mapper.removeEmployee(3); //增删改查完成后一定要手动提交
openSession.commit();
System.out.println(flag);
}finally{
openSession.close();
}
} }
Mybatis实例增删改查(二)的更多相关文章
- 学习MyBatis必知必会(5)~了解myBatis的作用域和生命周期并抽取工具类MyBatisUtil、mybatis执行增删改查操作
一.了解myBatis的作用域和生命周期[错误的使用会导致非常严重的并发问题] (1)SqlSessionFactoryBuilder [ 作用:仅仅是用来创建SqlSessionFactory,作用 ...
- MyBatis批量增删改查操作
前文我们介绍了MyBatis基本的增删该查操作,本文介绍批量的增删改查操作.前文地址:http://blog.csdn.net/mahoking/article/details/43673741 ...
- 从0开始完成SpringBoot+Mybatis实现增删改查
1.准备知识: 1)需要掌握的知识: Java基础,JavaWeb开发基础,Spring基础(没有Spring的基础也可以,接触过Spring最好),ajax,Jquery,Mybatis. 2)项目 ...
- Spring Boot入门系列(六)如何整合Mybatis实现增删改查
前面介绍了Spring Boot 中的整合Thymeleaf前端html框架,同时也介绍了Thymeleaf 的用法.不清楚的朋友可以看看之前的文章:https://www.cnblogs.com/z ...
- ssm 框架实现增删改查CRUD操作(Spring + SpringMVC + Mybatis 实现增删改查)
ssm 框架实现增删改查 SpringBoot 项目整合 一.项目准备 1.1 ssm 框架环境搭建 1.2 项目结构图如下 1.3 数据表结构图如下 1.4 运行结果 二.项目实现 1. Emplo ...
- MyBatis的增删改查。
数据库的经典操作:增删改查. 在这一章我们主要说明一下简单的查询和增删改,并且对程序接口做了一些调整,以及对一些问题进行了解答. 1.调整后的结构图: 2.连接数据库文件配置分离: 一般的程序都会把连 ...
- 一、数据库表中字段的增删改查,二、路由基础.三、有名无名分组.四、多app共存的路由分配.五、多app共存时模板冲突问题.六、创建app流程.七、路由分发.八、路由别名,九、名称空间.十、反向解析.十一、2.x新特性.十二、自定义转换器
一.数据库表中字段的增删改查 ''' 直接在modules中对字段进行增删改查 然后在tools下点击Run manage.py Task执行makemigrations和migrate 注意在执行字 ...
- 上手spring boot项目(三)之spring boot整合mybatis进行增删改查的三种方式。
1.引入依赖. <!--springboot的web起步依赖--><dependency> <groupId>org.springframework.boot< ...
- 上手spring boot项目(三)之spring boot整合mybatis进行增删改查
使用mybatis框架进行增删改查大致有两种基础方式,一种扩展方式.两种基础方式分别是使用xml映射文件和使用方法注解.扩展方式是使用mybatis-plus的方式,其用法类似于spring-data ...
随机推荐
- (转)海思平台HI35XX系列内存设置
海思平台的内存分为两部分,一部分给系统使用,另外的一部分给多媒体使用.可以通过cat /proc/meminfo查看系统内存和cat /proc/media-mem 查看多媒体内存使用情况. /pro ...
- Nginx MogileFS 配置
配置好MogileFS, 见mogilefs的安装与配置随笔 下载nginx.1.10.3.tar.gz, nginx_mogilefs_module.1.0.4.tar.gz 编译安装 将连个tar ...
- 制作的excel表格如何放到微信公众号文章中?
制作的excel表格如何放到微信公众号文章中? 我们都知道创建一个微信公众号,在公众号中发布一些文章是非常简单的,但公众号添加附件下载的功能却被限制,如今可以使用小程序“微附件”进行在公众号中添加附件 ...
- Windows下使用命令行编译Qt项目(解决DLL丢失问题)
一.前言 我之前用Qt做了个hello world,结果各种报错,一大堆DLL找不到,今天用命令行编译就通过了 二.准备工作 1.Visual Studio(有nmake就行) 2.Qt 3.把qma ...
- 云原生数据库mysql对共享存储分布式文件系统的接口需求分析
1. 引言 云原生数据库跟分布式mpp数据库是有差异的,虽然两者都是计算与存储分离,但是在资源的占用上有所不同.云原生数据库是shard everything架构,其依赖的存储资源.内存资源.事务资源 ...
- west_wild 靶机
ways:smb枚举+suid提权 1:扫描主机发现IP 老套路:netdiscover 一波 2:nmap扫描,发现开放的 端口很多并且开放是SMB协议 3:对目录扫描,发现没有可以利用的点 4:从 ...
- AMD 5700 XT显卡装ubuntu18.04.* 驱动的问题解决(全)
公司开发需要测试新的 AMD显卡,由于测试服务器上的显卡是英伟达的显卡所以换完后要安装相应的驱动.由于之前装机的同事装的ubuntu是18.04.5 恰巧18.04.5在amd官网上没有相匹配的驱动( ...
- ms14-064漏洞复现
本博客最先发布于我的个人博客,如果方便,烦请移步恰醋的小屋查看,谢谢您! 这是我在实验室学习渗透测试的第五个漏洞复现,一个多小时便完成了.学长给的要求只需完成查看靶机信息.在指定位置创建文件夹两项操作 ...
- [PyTorch 学习笔记] 1.1 PyTorch 简介与安装
PyTorch 的诞生 2017 年 1 月,FAIR(Facebook AI Research)发布了 PyTorch.PyTorch 是在 Torch 基础上用 python 语言重新打造的一款深 ...
- C++判断是回文串还是镜像串
#include <iostream> #include <string> #include <cstdio> #include <cctype> #p ...