首页 > 其他分享 >【重温SSM框架系列】11 - Mybatis快速入门(JDBC、开发步骤,配置文件)

【重温SSM框架系列】11 - Mybatis快速入门(JDBC、开发步骤,配置文件)

时间:2022-12-06 10:39:19浏览次数:58  
标签:11 username JDBC 配置文件 public user mybatis password id


Mybatis快速入门

  • ​​准备工作​​
  • ​​原始JDBC操作​​
  • ​​查询​​
  • ​​插入​​
  • ​​mybatis简介与开发步骤​​
  • ​​1. 引入mybatis依赖包​​
  • ​​2. 创建表和对应实体类​​
  • ​​3. 编写映射文件UserMapper.xml​​
  • ​​4. 配置mybatis核心配置文件​​
  • ​​mybatis的增删改查​​
  • ​​插入操作​​
  • ​​删除操作​​
  • ​​修改操作​​
  • ​​查询操作​​
  • ​​核心配置文件常用标签​​

大家好,我是【1+1=王】, 热爱java的计算机(人工智能)渣硕研究生在读。
如果你也对java、人工智能等技术感兴趣,欢迎关注,抱团交流进大厂!!!
Good better best, never let it rest, until good is better, and better best.

近期会重新温习一下SSM的相关知识,相应的博客会更新至专栏【SSM框架】中,欢迎大家关注!

准备工作

1. 创建user表

【重温SSM框架系列】11 - Mybatis快速入门(JDBC、开发步骤,配置文件)_mybatis


2. 创建User实体类

public class User {
private Integer id;
private String username;
private String password;

public User() {
}

public User(String username, String password) {
this.username = username;
this.password = password;
}

public User(Integer id, String username, String password) {
this.id = id;
this.username = username;
this.password = password;
}

public Integer getId() {
return id;
}

public void setId(Integer id) {
this.id = id;
}

public String getUsername() {
return username;
}

public void setUsername(String username) {
this.username = username;
}

public String getPassword() {
return password;
}

public void setPassword(String password) {
this.password = password;
}

@Override
public String toString() {
return "User{" +
"id=" + id +
", username='" + username + '\'' +
", password='" + password + '\'' +
'}';
}
}

3. 引入mysql驱动

<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.6</version>
</dependency>

原始JDBC操作

查询

public static List<User> findAll() throws Exception {
Class.forName("com.mysql.jdbc.Driver");

Connection conn = DriverManager.getConnection("jdbc:mysql:///test", "root", "123456");
String sql = "select * from user";
PreparedStatement pstmt = conn.prepareStatement(sql);
ResultSet rs = pstmt.executeQuery();

List<User> userList = new ArrayList<User>();
while(rs.next()){
User user = new User();
user.setId(rs.getInt("id"));
user.setUsername(rs.getString("username"));
user.setPassword(rs.getString("password"));

userList.add(user);
}
rs.close();
pstmt.close();
conn.close();
return userList;
}

插入

public static void insertUser(User user) throws Exception{
Class.forName("com.mysql.jdbc.Driver");

Connection conn = DriverManager.getConnection("jdbc:mysql:///test", "root", "123456");
String sql = "insert into user(id,username,password) values(?,?,?)";
PreparedStatement pstmt = conn.prepareStatement(sql);
pstmt.setInt(1,user.getId());
pstmt.setString(2,user.getUsername());
pstmt.setString(3,user.getPassword());

int i = pstmt.executeUpdate();
System.out.println(i);

pstmt.close();
conn.close();
}

mybatis简介与开发步骤

  • mybatis是一个优秀的基于java的持久层框架,它内部封装了jdbc,使开发者只需要关注sql语句本身,而不需要花费精力去处理加载驱动、创建连接、创建statement等繁杂的过程。
  • mybatis通过xml或注解的方式将要执行的各种statement配置起来,并通过java对象和statement中sql的动态参数进行映射生成最终执行的sql语句。
  • 最后mybatis框架执行sql并将结果映射为java对象并返回。采用ORM思想解决了实体和数据库映射的问题,对jdbc进行了封装,屏蔽了jdbcapi底层访问细节,使我们不用与jdbcapi打交道,就可以完成对数据库的持久化操作。

MyBatis官网地址:​​http://www.mybatis.org/mybatis-3/​

1. 引入mybatis依赖包

<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.4.5</version>
</dependency>

2. 创建表和对应实体类

同上。

【重温SSM框架系列】11 - Mybatis快速入门(JDBC、开发步骤,配置文件)_mapper映射文件_02

3. 编写映射文件UserMapper.xml

在resources目录下创建文件com/wang/mapper/UserMapper.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="userMapper">
<select id="findAll" resultType="com.wang.pojo.User">
select * from user
</select>
</mapper>

【重温SSM框架系列】11 - Mybatis快速入门(JDBC、开发步骤,配置文件)_mybatis核心配置_03

4. 配置mybatis核心配置文件

在resources目录下创建文件sqlMapConfig.xml. 并添加相应配置

<configuration>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql:///test"/>
<property name="username" value="root"/>
<property name="password" value="123456"/>
</dataSource>
</environment>
</environments>

<mappers>
<!-- 映射文件所在位置-->
<mapper resource="com/wang/mapper/UserMapper.xml"/>
</mappers>
</configuration>

测试

public static void main(String[] args) throws IOException {
//加载核心配置文件
InputStream inputStream = Resources.getResourceAsStream("sqlMapConfig.xml");
//获得sqlSession工厂对象
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
//获得sqlSession对象
SqlSession session = sqlSessionFactory.openSession();
//执行sql语句
List<User> userList = session.selectList("userMapper.findAll");

Iterator<User> iterator = userList.iterator();
while(iterator.hasNext()){
System.out.println(iterator.next());
}

session.close();
}

【重温SSM框架系列】11 - Mybatis快速入门(JDBC、开发步骤,配置文件)_mapper映射文件_04

mybatis的增删改查

插入操作

  1. 映射文件加入
<insert id="add" parameterType="com.wang.pojo.User">
insert into user(id,username,password) values(#{id},#{username},#{password})
</insert>
  1. 测试
@Test
public void add() throws Exception{
//加载核心配置文件
InputStream inputStream = Resources.getResourceAsStream("sqlMapConfig.xml");
//获得sqlSession工厂对象
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
//获得sqlSession对象
SqlSession session = sqlSessionFactory.openSession();
//执行sql语句
int insert = session.insert("userMapper.add",new User("Curry","30303030"));
System.out.println(insert);

session.commit();
session.close();
}

3. 注意

  • 插入语句使用insert标签
  • 在映射文件中使用parameterType属性指定要插入的数据类型
  • Sql语句中使用#{实体属性名}方式引用实体中的属性值
  • 插入操作使用的API是sqlSession.insert(“命名空间.id”,实体对象);
  • 插入操作涉及数据库数据变化,所以要使用sqlSession对象显示的提交事务,即sqlSession.commit()

删除操作

  1. 映射文件加入
<delete id="delete" parameterType="java.lang.Integer">
delete from user where id=#{id}
</delete>
  1. 测试
@Test
public void delete() throws Exception{
//加载核心配置文件
InputStream inputStream = Resources.getResourceAsStream("sqlMapConfig.xml");
//获得sqlSession工厂对象
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
//获得sqlSession对象
SqlSession session = sqlSessionFactory.openSession();
//执行sql语句
int delete = session.delete("userMapper.delete",1); //删除id=1的user
System.out.println(delete);

session.commit();
session.close();
}

3. 注意

  • 删除语句使用delete标签
  • Sql语句中使用#{任意字符串}方式引用传递的单个参数
  • 删除操作使用的API是sqlSession.delete(“命名空间.id”,Object);

修改操作

  1. 映射文件加入
<update id="update" parameterType="com.wang.pojo.User">
update user set username=#{username},password=#{password} where id=#{id}
</update>
  1. 测试
@Test
public void update() throws Exception{
//加载核心配置文件
InputStream inputStream = Resources.getResourceAsStream("sqlMapConfig.xml");
//获得sqlSession工厂对象
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
//获得sqlSession对象
SqlSession session = sqlSessionFactory.openSession();
//执行sql语句
int update = session.update("userMapper.update",new User(2,"科比","24-8")); //删除id=2的user
System.out.println(update);

session.commit();
session.close();
}

3. 注意

  • 修改语句使用update标签
  • 修改操作使用的API是sqlSession.update(“命名空间.id”,实体对象);

查询操作

见上述开发步骤,这里不再重复。

核心配置文件常用标签

【重温SSM框架系列】11 - Mybatis快速入门(JDBC、开发步骤,配置文件)_mapper映射文件_05


1. environments标签

【重温SSM框架系列】11 - Mybatis快速入门(JDBC、开发步骤,配置文件)_增删改查_06

事务管理类型有两种

  1. JDBC:使用了JDBC 的提交和回滚设置,它依赖于从数据源得到的连接来管理事务作用域。
  2. MANAGED:这个配置几乎没做什么。它从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期(比如JEE 应用服务器的上下文)。默认情况下它会关闭连接,然而一些容器并不希望这样,因此需要将closeConnection属性设置为false 来阻止它默认的关闭行为。

数据源类型有三种:

  1. UNPOOLED:这个数据源的实现只是每次被请求时打开和关闭连接。
  2. POOLED:这种数据源的实现利用“池”的概念将JDBC 连接对象组织起来。
  3. JNDI:这个数据源的实现是为了能在如EJB 或应用服务器这类容器中使用,容器可以集中或在外部配置数据源,然后放置一个JNDI 上下文的引用。

2. mapper标签
mapper标签用于加载映射文件。
加载方式有如下几种:

  • 使用相对于类路径的资源引用,例如:​​<mapper resource="com/wang/mapper/UserMapper.xml"/>​
  • 使用完全限定资源定位符(URL),例如:​​<mapper url="file:///mapper/UserMapper.xml"/>​
  • 使用映射器接口实现类的完全限定类名,例如:​​<mapper class="com.wang.mapper.UserMapper"/>​
  • 将包内的映射器接口实现全部注册为映射器,例如:​​<package name="com.wang.mapper"/>​

3. properties标签

properties标签加载额外配置的properties文件,例如将数据源的配置信息单独抽取成一个properties文件。

【重温SSM框架系列】11 - Mybatis快速入门(JDBC、开发步骤,配置文件)_mapper映射文件_07

【重温SSM框架系列】11 - Mybatis快速入门(JDBC、开发步骤,配置文件)_ssm_08


4. typeAliases标签

在映射文件中为SQL参数类型或者返回类型的时候,需要配置全包名,这就比较烦人。

【重温SSM框架系列】11 - Mybatis快速入门(JDBC、开发步骤,配置文件)_mybatis核心配置_09


这是就可以使用typeAliases标签,为Java 类型设置一个短的名字。

<typeAliases>
<typeAlias type="com.wang.pojo.User" alias="user"/>
</typeAliases>

【重温SSM框架系列】11 - Mybatis快速入门(JDBC、开发步骤,配置文件)_ssm_10

mybatis框架已经为我们设置好的一些常用的类型的别名

【重温SSM框架系列】11 - Mybatis快速入门(JDBC、开发步骤,配置文件)_mybatis核心配置_11



标签:11,username,JDBC,配置文件,public,user,mybatis,password,id
From: https://blog.51cto.com/u_15901218/5914764

相关文章

  • 11
    包头医学院医学影像学专业本科人才培养方案一、专业概况学科门类:医学专业名称:医学影像学专业代码:100203TK授予学位:医学学士标准学制:五年二、培养目标培养适应内蒙......
  • [C++11与并发编程]读写锁的简单实现
    读写锁的简单实现layout:posttitle:读写锁categories:cpp_concurrencydescription:C++并发编程简介keywords:c++,并发编程,读写锁​​boost共享锁实现​​​读写......
  • 你应该知道的11个React Native组件库
    你应该知道的11个ReactNative组件库 2021-12-0417:59 1165阅读  0赞随着React的日益流行和原生移动应用开发(和PWA)的崛起,ReactNative的采用率也在增长。与Rea......
  • ArcObjects SDK开发 011 RasterLayer
    1、RasterLayer的结构图层的话,除了FeatureLayer外,用的最多的就是RasterLayer了。较FeatureLayer而言,RasterLayer比较简单,这点可以从栅格图层的属性对话框中可以看出。其......
  • termux配置文件分享
    termux版本:这里猫猫比较喜欢termux-monet,带有monet取色支持和背景自定义。链接:HardcodedCat/termux-monet欢迎信息:原版:Generator/termux-motd修改版:Moe-hacker/termux......
  • Linux Debian11使用Podman安装DVWA靶场环境
    一、DVWA靶场环境简介​1.DVWA一个用来进行安全脆弱性鉴定的PHP/MySQLWeb应用,旨在为安全专业人员测试自己的专业技能和工具提供合法的环境,帮助web开发者更好的理解web应用......
  • JDBC
    1.加载驱动/*mysql5.+的版本加载驱动com.mysql.jdbc.Driver;8.0后的版本是com.mysql.cj.jdbc.Driver*/2.提供url,用户信息mysql端口号--3306协议://主机地址:端......
  • day44 6-9 spring框架IOC与AOP(视频) & 6-10 集成mybatis框架 & 6-11 mybatis映射文件标
    MyBatis什么是持久化将数据(如内存中对象)保存到可以永久保存的存储设备中(如磁盘),持久化的主要应用是将内存的数据存储在关系型数据库中,也可存储在磁盘文件、xml数据文件中......
  • oracle 11g单表恢复
    文档课题:oracle11g单表恢复.数据库:oracle11.2.0.464位系统:oel7.964位1、非rman方式1.1、flashback恢复[oracle@oel~]$exportNLS_DATE_FORMAT='yyyy-mm-ddhh24:mi:s......
  • VMware Fusion 13虚拟机如何安装win 11教程
    VM虚拟机如何安装win11?还不知道如何在VMwareFusion13虚拟机中安装win11的朋友,下面就和小编一起来了解一下!1、运行VMwareFusion13虚拟机,在「新建虚拟机」界面上,拖拽......