java全栈day21--Web后端实战之利用Mybaits查询数据

一、需求:

查询数据库表中的所有部门数据,展示在页面上。

二、准备工作:

  1. 准备数据库表 dept (部门表),实体类 Dept 。
  1. 在项目中引入 mybatis 的起步依赖, mysql 的驱动包。
  1. 在项目的 application.properties 中引入 mybatis 的配置信息(数据库连接、日志输出)。

 代码实现:

  1. 定义 mapper 包,并且定义 DeptMapper 接口,并声明接口方法。
  1. 改造之前编写的 dao 、 service 的代码,在 service 实现中注入 mapper 接口。

运行结果

打开接口测试工具apifox

打开nginx进行前后端联调测试

补充:

数据封装

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

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

(java里面定义类属性不带下划线,数据库里面带下划线)

方法一:

不能自动封装,进行手动结果映射:通过 @Results 及 @Result 进行手动结果映射。

方法二:

起别名:在 SQL 语句中,对不一样的列名起别名,别名和实体类属性名一样。

方式三:(工作当中使用)

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

(这种方法要求数据库字段必须是下划线(create_time)分隔,属性必须采用驼峰(createTime))

小结

相关推荐
Ws_2 小时前
C#学习 Day2
开发语言·学习·c#
lcreek2 小时前
Java 反序列化漏洞深度解析(一):从URLDNS到真正的DNS探测
java·反序列化漏洞
杰克尼2 小时前
天机学堂复习总结(day03-day04)
java·开发语言·redis·elasticsearch·spring cloud
x***r1513 小时前
jdk-11.0.16.1_windows使用步骤详解(附JDK 11环境变量配置与验证教程)
java·开发语言·windows
弹简特3 小时前
【Java项目-轻聊】01-项目演示+项目介绍+准备工作+项目源码
java
luck_bor4 小时前
File类&递归作业
java·开发语言
武子康4 小时前
Java-07 深入浅出 MyBatis数据库一对多关系模型实战:表结构设计与查询实现
java·后端
REDcker6 小时前
Linux OverlayFS详解
java·linux·运维
Royzst6 小时前
xml知识点
java·服务器·前端
鱼鳞_7 小时前
苍穹外卖-Day08(缓存套餐)
java·redis·缓存