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))

小结

相关推荐
爱吃山竹的大肚肚3 分钟前
微服务间通过Feign传输文件,处理MultipartFile类型
java·spring boot·后端·spring cloud·微服务
_周游10 分钟前
Java8 API文档搜索引擎_使用内存缓冲区优化
java·搜索引擎·intellij-idea
twj_one11 分钟前
java中23种设计模式
java·开发语言·设计模式
梵刹古音13 分钟前
【C语言】 跳转语句
c语言·开发语言·算法
tsyjjOvO27 分钟前
JDBC(Java Database Connectivity)
java·数据库
阿猿收手吧!30 分钟前
【C++】C++模板特化:精准定制泛型逻辑
开发语言·c++·算法
qq_124987075331 分钟前
基于springboot的尿毒症健康管理系统的设计与实现(源码+论文+部署+安装)
java·spring boot·spring·毕业设计·计算机毕业设计
ghie90901 小时前
MATLAB中编写不平衡磁拉力方程
开发语言·matlab
weixin_452159551 小时前
C++与Java性能对比
开发语言·c++·算法
会叫的恐龙1 小时前
C++ 核心知识点汇总(第一日)(输入输出与变量、类型转换)
开发语言·c++