28.Mybatis的入门

news/2024/9/22 18:14:45/

目录

一、Mybatis的入门。

(1)Mybatis的简介。 

(2)Mybatis的快速入门。

(2.1)快速入门。 

(2.2)UserMapper.xml文件。

(2.3)sqlMapConfig.xml文件。

(2.4)测试类代码。

(3)MyBatis的映射文件概述。

(4)MyBatis的增删改查操作。

 (4.1)查询操作。

(4.2)插入操作。

(4.3)修改操作。

(4.4)删除操作。

(4.5)增删改查映射配置知识小结。


一、Mybatis的入门。

(1)Mybatis的简介。 

Mybatis是一个持久层框架。 

(2)Mybatis的快速入门。

(2.1)快速入门。 

(2.2)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="domain.User">select * from user</select>
</mapper>

(2.3)sqlMapConfig.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><!--数据源环境--><environments default="development"><!--默认使用下面id为development的环境--><environment id="development"><transactionManager type="JDBC"></transactionManager><dataSource type="POOLED"><property name="driver" value="com.mysql.cj.jdbc.Driver"/><property name="url" value="jdbc:mysql://localhost:3306/test"/><property name="username" value="root"/><property name="password" value="tan"/></dataSource></environment></environments><!--加载映射文件--><mappers><mapper resource="mapper/UserMapper.xml"></mapper></mappers>
</configuration>

(2.4)测试类代码。

package test;
public class MyBatisTest {@Testpublic void test1() throws IOException {//1.获取核心配置文件InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");//2.获得session工厂对象SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);//3.获取session会话对象SqlSession sqlSession = sqlSessionFactory.openSession();//4.执行操作List<User> userList = sqlSession.selectList("userMapper.findAll");//5.打印数据System.out.println(userList);//6.释放资源sqlSession.close();}
}

(3)MyBatis的映射文件概述。

(4)MyBatis的增删改查操作。

 (4.1)查询操作。

<?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"><!--1、查询操作--><select id="findAll" resultType="domain.User">select * from user</select><!--2、插入操作--><insert id="save" parameterType="domain.User">insert into user values (#{id},#{username},#{password})</insert><!--3、修改操作--><update id="update" parameterType="domain.User">update user set username=#{username},password=#{password} where id = #{id}</update><!--4、删除操作--><delete id="delete" parameterType="java.lang.Integer">delete from user where id = #{id}</delete>
</mapper>
    @Test//查询操作public void test1() throws IOException {//1.获取核心配置文件InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");//2.获得session工厂对象SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);//3.获取session会话对象SqlSession sqlSession = sqlSessionFactory.openSession();//4.执行操作List<User> userList = sqlSession.selectList("userMapper.findAll");//5.打印数据System.out.println(userList);//6.释放资源sqlSession.close();}

(4.2)插入操作。

<?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"><!--2、插入操作--><insert id="save" parameterType="domain.User">insert into user values (#{id},#{username},#{password})</insert>
</mapper>
    @Test//插入操作public void test2() throws IOException {//模拟user对象User user = new User();//user.setId(-1);//设置为0(不设置,默认为0)则自增,设置其他不自增(负数,整数,导致都不会自增)user.setUsername("asss");user.setPassword("abc");//1.获取核心配置文件InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");//2.获得session工厂对象SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);//3.获取session会话对象SqlSession sqlSession = sqlSessionFactory.openSession();//4.执行操作 参数:namespace+id(命名空间.id)sqlSession.insert("userMapper.save",user);//5.mybatis执行更新操作,提交事务sqlSession.commit();//6.释放资源sqlSession.close();}

(4.3)修改操作。

<?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"><!--3、修改操作--><update id="update" parameterType="domain.User">update user set username=#{username},password=#{password} where id = #{id}</update>
</mapper>
    @Test//修改操作public void test3() throws IOException {//模拟user对象User user = new User();user.setId(-1);user.setUsername("lucy");user.setPassword("123");//1.获取核心配置文件InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");//2.获得session工厂对象SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);//3.获取session会话对象SqlSession sqlSession = sqlSessionFactory.openSession();//4.执行操作 参数:namespace+id(命名空间.id)sqlSession.update("userMapper.update",user);//5.mybatis执行更新操作,提交事务sqlSession.commit();//6.释放资源sqlSession.close();}

(4.4)删除操作。

<?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"><!--4、删除操作--><delete id="delete" parameterType="java.lang.Integer">delete from user where id = #{id}</delete>
</mapper>
    @Test//删除操作public void test4() throws IOException {//1.获取核心配置文件InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");//2.获得session工厂对象SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);//3.获取session会话对象SqlSession sqlSession = sqlSessionFactory.openSession();//4.执行操作 参数:namespace+id(命名空间.id)sqlSession.delete("userMapper.delete",8);//5.mybatis执行更新操作,提交事务sqlSession.commit();//6.释放资源sqlSession.close();}

(4.5)增删改查映射配置知识小结。

 (5)待续......


http://www.ppmy.cn/news/56347.html

相关文章

华为云 绑定/更换证书

操作场景 为了支持HTTPS数据传输加密认证&#xff0c;在创建HTTPS协议监听的时候需绑定证书&#xff0c;您可以参考本章节绑定证书。如果弹性负载均衡实例使用的证书过期或者其它原因需要更换&#xff0c;您可以参考本章节更换证书。如果还有其他的服务也使用了待更换的证书&a…

内网渗透之横向移动NTMLRelay(中继)攻击-InveighNTLM-Relay重放

横向移动 NTLM中继攻击 Relay重放(smb) 适用于无法获取hash或密码时使用 NTML Relay重放包括smb to relay ldap ews webserver: 执行下面的命令时会默认以当前用户名和密码去登录目标计算机 dir \\ 192.168.3.32\c$webserver切换到本地的administrator时 dir \\ 192.168.3.3…

「华熙生物」发来感谢信,企企通赋能生物科技领域数字化采购建设

近日&#xff0c;华熙生物科技股份有限公司&#xff08;以下简称“华熙生物”&#xff09;携手企企通打造的数字化采购管理平台成功上线。为感谢企企通在采购数字化项目上的付出和努力&#xff0c;华熙生物特意发来暖心感谢信。 在感谢信中&#xff0c;华熙生物表示&#xff1a…

【LeetCode】222.完全二叉树的节点数

1.问题 给你一棵 完全二叉树 的根节点 root &#xff0c;求出该树的节点个数。 完全二叉树 的定义如下&#xff1a;在完全二叉树中&#xff0c;除了最底层节点可能没填满外&#xff0c;其余每层节点数都达到最大值&#xff0c;并且最下面一层的节点都集中在该层最左边的若干位…

fengMap蜂鸟免费地图使用时报错:Uncaught Error: invalid wire type xx at offset xx

目录 一、问题 二、原因及解决方法 三、总结 tips:如嫌繁琐,直接看总结即可 一、问题 1.加载蜂鸟提供的免费地图时一直报错,无法正常加载地图: 1)具体错误:ngmap.map.min.js:1104 Uncaught Error: invalid wire type 7 at offset 47 at u.skipType (fengmap.map.m…

【2023 年第十三届 MathorCup 高校数学建模挑战赛】A 题 量子计算机在信用评分卡组合优化中的应用 42页论文及代码

【2023 年第十三届 MathorCup 高校数学建模挑战赛】A 题 量子计算机在信用评分卡组合优化中的应用 42页论文及代码 相关信息 【2023 年第十三届 MathorCup 高校数学建模挑战赛】A 题 量子计算机在信用评分卡组合优化中的应用 详细建模过程解析及代码实现 1 题目 在银行信用…

【chatGPT 对JavaScript中的类是如何解释的】

chatGPT 对JavaScript中的类是如何解释的 问1&#xff1a;在js中类定义好后&#xff0c;方法与属性应怎样定&#xff0c;它有格式吗&#xff1f; 答1&#xff1a; 在JavaScript中定义类的方式有多种&#xff0c;其中一种是使用ES6的class关键字。在使用class定义类时&#x…

结构型模式-装饰者模式

装饰者模式 概述 我们先来看一个快餐店的例子。 快餐店有炒面、炒饭这些快餐&#xff0c;可以额外附加鸡蛋、火腿、培根这些配菜&#xff0c;当然加配菜需要额外加钱&#xff0c;每个配菜的价钱通常不太一样&#xff0c;那么计算总价就会显得比较麻烦。 使用继承的方式存在…