java全栈day20--Web后端实战(Mybatis基础2)

一、Mybatis基础

1.1辅助配置

配置 SQL 提示。

默认在 mybatis 中编写 SQL 语句是不识别的。可以做如下配置:

现在就有sql提示了

新的问题

产生原因: Idea 和数据库没有建立连接,不识别表信息

解决方式:在 Idea 中配置 MySQL 数据库连接

可以了不冒红(可以建立多个连接)

配置 Mybatis 的日志输出

1.2 JCBD VS Mybaits

1.3数据库连接池

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

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

释放空闲时间超过最大空闲时间的连接,来避免因为没有释放连接而引起的数据库连接遗漏(比如,一个sql用了一个连接,但它迟迟没有使用,就无法归还,连接越用越少)。

怎么解决呢:连接池里面有一个类似定时器的东西,如果持续不释放,定时到了会强制归还连接

优势:

  1. 资源重用

  2. 提升系统响应速度

  3. 避免数据库连接遗漏

标准接口: DataSource

官方 (sun) 提供的数据库连接池接口,由第三方组织实现此接口。

功能:获取连接

推荐使用

咱们的入门程序是Hikari,默认的

现在咱们来切换

结果

小结

数据库连接池

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

优势:资源复用、提升系统响应速度

接口: DataSource

产品: C3P0 、 DBCP 、 Druid 、 Hikari

1.4 XML映射配置

前言:咱们的Mybaits当中sql语句是定义在注解里面。

下面解释另一种方法,可以将sql语句定义在XML文件中。

在 Mybatis 中,既可以通过注解配置 SQL 语句,也可以通过 XML 配置文件配置 SQL 语句。

规则:

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

扩展一下

  1. XML 映射文件的 namespace 属性为 Mapper 接口全限定名一致。
  1. XML 映射文件中 sql 语句的 id 与 Mapper 接口中的方法名一致,并保持返回类型一致。

在sql语句(select....)查询完成之后,每一条记录都需要封装到User对象当中

结果

XML映射文件

提高XML效率

那在 Mybatis 的开发中,到底使用注解开发还是使用 XML 开发呢 ?

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

小结

相关推荐
little_xianzhong13 小时前
关于对逾期提醒的定时任务~改进完善
java·数据库·spring boot·spring·mybatis
yuluo_YX13 小时前
Go Style 代码风格规范
开发语言·后端·golang
百锦再13 小时前
脚本语言的大浪淘沙或百花争艳
java·开发语言·人工智能·python·django·virtualenv·pygame
小猪咪piggy13 小时前
【JavaEE】(23) 综合练习--博客系统
java·数据库·java-ee
周航宇JoeZhou13 小时前
JP4-7-MyLesson后台前端(五)
java·前端·vue·elementplus·前端项目·mylesson·管理平台
David爱编程13 小时前
从 JVM 到内核:synchronized 与操作系统互斥量的深度联系
java·后端
渣哥13 小时前
Java Set 不会重复?原来它有“记仇”的本事!
java
一叶飘零_sweeeet13 小时前
从 0 到 1 攻克订单表分表分库:亿级流量下的数据库架构实战指南
java·数据库·mysql·数据库架构·分库分表
苹果醋314 小时前
数据库索引设计:在 MongoDB 中创建高效索引的策略
java·运维·spring boot·mysql·nginx
Dontla14 小时前
Dockerfile解析器指令(Parser Directive)指定语法版本,如:# syntax=docker/dockerfile:1
java·docker·eureka