当前位置: 首页 > news >正文

Mybatis(黑马)

入门

概念

:是一款优秀的持久层框架,用于简化JDBC的开发

          就是通过java程序来操作数据库

快速入门

:1.准备工作(创建springboot工程、数据库表user、实体类user)

                  2.引入Mybatis的相关依赖,配置Mybatis(数据库连接信息)

                  3.编写SQL语句(注解/XML)

数据库连接池

概念:数据库连接池是个容器,负责分配、管理数据库连接(Connection)

          它允许应用程序重复使用一个现有的数据库连接,而不是再重新建立一个

          释放空闲时间超过最大空闲时间的连接,来避免因为没有释放连接而引起的数据库连接遗漏

优势:资源重用、提升系统响应速度、避免数据库连接遗漏

切换Druid数据库连接池:

  1.先引入依赖

<dependency>

   <groupld>com.alibaba</groupld>

   <artifactld>druid-spring-boot-starter</artifactld>

   <version>1.2.8</version>

</dependency>

 2.配置属性

spring.datasource.druid.driver-class-name=com.mysql.cj.jdbc.Drive

spring.datasource.druid.url=jdbc:mysql://localhost:3306/mybatis

spring.datasource.druid.username=root

spring.datasource.druid.password=1234

lombok

Lombok是一个实用的java类库,能通过注解的形式自动生成构造器、getter/setter、equals、hashcode、tostring.等方法,并可以自动化生成日志变量,简化java开发、提高效率。

要引入依赖

<dependency>

    <groupld>org.projectlombok</groupld>

    <artifactld>lombok</artifactld>

</dependency>

基础操作

删除

1.方法(根据主键删除)

SQL语句:   delete from emp where id = 17;

接口方法:

@Delete("delete from emp where id = #{id}")

public void delete(integer id);

注:

配置日志:可以在application.properties中,打开mybatis的日志,并指定输出到控制台#指定

mybatis输出日志的位置,输出控制台

新增

1.方法

SQL语句:

insert into emp(username, name, gender, image, job, entrydate, dept id, create time, update time) values ('songyuanqiao'“宋远桥',1,1jpg'2,'2012-10-09'2,2022-10-0110:00:00','2022-10-01 10:00:00');

接口方法:

@Insert("insert into emp(username, name, gender, image, job, entrydate, dept id, create time, update time) " + "values(#username, #name}, #{gender), #{image), #ljob), #entrydatel, #deptld), #{createTime), #{updateTime)")

public void insert(Emp emp);

注:红色的Emp是一个实体类将多个数据进行了封装,在数据传输时可以使用一个对象传输

更新(修改)

1.方法  (根据ID更新员工信息)

SOL语句

update emp set username = 'songdaxia', name = '宋大侠', gender = 1 ,image = '1.jpg', job =2, entrydate ='2012-01-01',dept id=2,update time='2022-10-01 12:12:12' where id = 19;

接口方法

@Update("update emp set username=#fusernamel, name=#{namel, gender=#genderl, image=#imagel, iob=#ioblentrydate=#{entrydate}, dept id=#{deptld), update time=#{updateTime} where id=#{id}")

public void update(Emp emp);

查询

1.根据id查询

SOL语句

select * from emp where id = 19;

接口方法

@Select("select * from emp where id = #{id}")

public Emp getByld(integer id);

注:


数据封装:实体类属性名 和 数据库表查询返回的字段名一致,mybatis会自动封装。

                   如果实体类属性名 和 数据库表查询返回的字段名不一致,不能自动封装。.
例:

解决办法:
1.起别名:在SQL语句中,对不一样的列名起别名,别名和实体类属性名一样。

@select("select id, username, password, name, gender, image, job, entrydate, dept id deptid, create time createTime, update timeupdateTime from emp where id = #{id} ")

public Emp getByld(Integer id);

   2.手动结果映射:通过 @Results及@Result 进行手动结果映射。.

@Select("select * from emp where id = #{id}")
@Results({
@Result(column = "dept id", property= "deptld"),
@Result(column ="create time", property = "createTime"),
@Result(column="update time", property="updateTime")})
public Emp getByld(integer id);

   3.开启驼峰命名:如果字段名与属性名符合驼峰命名规则,mybatis会自动通过驼峰命名规则映射

2.根据条件查询

SQL语句
select * from emp where name like "%;k%' and gender= 1 and entnydate between'2010-01-01' and '2020-01-01 'order by update time desc;

接口方法

1.  @Select("select* from emp where name like '%${name}%' and gender #gender} and entrydate between #{begin} and #{end} order by update time desc")

public List<Emp> list(String name,,Short gender,LocalDate begin,LocalDate end;


2.  @select"select * from emp where name like concat('%',#name,’%') and gender = #{gender} and entrydate between #{begin} and #{end} order by update _ time desc")

public List<Emp> list(String name, Short gender , LocalDate begin , LocalDate end);
推荐


XML映射文件

规范

XML映射文件的名称与Mapper接口名称一致,并且将XML映射文件和Mapper接口放置在相同包下(同包同名)

XML映射文件的namespace属性为Mapper接口全限定名一致。。

XML映射文件中sql语句的id与Mapper接口中的方法名一致,并保持返回类型一致。

<mapper namespace="com.itheima.mapper.EmpMapper">

   <select id="list"  resultType="com.itheima.pojo.Emp">

          select * from emp where name like concat('%',#{name},'%’) and gender = #{gender} and

                entrydate between #{begin} and #{end} order by update time desc

   </select>

</mapper>


注: 使用Mybatis的注解,主要是来完成一些简单的增删改查功能。如果需要实现复杂的SQL功能,建议使用XML来配置映射语句。

动态SQL

动态SQL:随着用户的输入或外部条件的变化而变化的SQL语句,我们称为 动态SQL。

<if>

<if>:用于判断条件是否成立。使用test属性进行条件判断,如果条件为true,则拼接SQL。

<where>:where 元素只会在子元素有内容的情况下才插入where子句。而且会自动去除子句的开头

的AND 或OR。


<foreach>

SOL语句

delete from emp where id in (1,2,3);

接口方法

public void deleteBylds(List<integer> ids);


XML映射文件

<delete id="deleteBylds">

      delete from emp where id in

      <foreach collection="ids" item="id" separator="," open="(" close=")">

           #{id}

      </foreach>

</delete>

sql&include

如果在文件中存在大量重复的SQL语句片段,后续改动时会很繁琐,可以使用sql&include来解决。

http://www.dtcms.com/a/278740.html

相关文章:

  • H.264编解码(NAL)
  • 本地小市值miniqmt开发成功
  • 【无标题】Go迭代器完全指南:从基础到实战
  • 行为模式-观察者模式
  • grpo nl2sql qwen3 模型强化学习训练有效果的成立条件有哪些
  • java+vue+SpringBoo智慧草莓基地管理系统(程序+数据库+报告+部署教程+答辩指导)
  • 岳飞:精忠报国的千古英雄
  • 【基础架构】——架构设计流程第三步(评估和选择备选方案)
  • 什么是实时数仓?实时数仓又有哪些应用场景?
  • Kubernetes 高级调度01
  • 【Linux】基本指令详解(一) 树状文件结构、家目录、绝对/相对路径、linux文件类型
  • 【Linux】Jenkins Lts 配置构建 Maven 项目
  • 制作一款打飞机游戏80:道具碰撞
  • FastAPI-P1:Pydantic模型与参数额外信息
  • ThreadLocal结构
  • 02 51单片机之LED闪烁
  • 用TensorFlow进行逻辑回归(三)
  • 计算机网络通信的相关知识总结
  • Faiss库
  • 玩转Docker | 使用Docker部署TeamMapper思维导图应用程序
  • JavaScript 性能优化实战:深入性能瓶颈,精炼优化技巧与最佳实践
  • 深入理解MyBatis延迟加载:原理、配置与实战优化
  • 浏览器自动化领域的MCP
  • Ubuntu22.04 python环境管理
  • 前端常见十大问题讲解
  • priority_queue的使用和模拟实现以及仿函数
  • 【记忆化搜索 BFS】P9038 [PA 2021] Butelki|普及+
  • 赋能公安行业信息化PPT(46页)
  • 软考 系统架构设计师系列知识点之杂项集萃(111)
  • [C语言语法笔记] 批量处理错误 goto