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

小结

相关推荐
想进大厂的小徐2 分钟前
Spring 容器启动与 Bean 创建流程
java·spring boot·spring
dreamxian4 分钟前
微服务1 -- MybatisPlus
java·微服务·架构
糖炒栗子03266 分钟前
后端异步任务编排:基于 RabbitMQ 的“中控-工人”模式
java·rabbitmq
sycmancia15 分钟前
Qt——窗口部件及窗口类型、坐标系统
开发语言·qt
南境十里·墨染春水16 分钟前
C++ 笔记 运算符重载(面象对象)
开发语言·c++·笔记
小陈工18 分钟前
Python Web开发入门(一):虚拟环境与依赖管理,从零搭建纯净开发环境
开发语言·前端·数据库·git·python·docker·开源
SimonKing18 分钟前
紧急自查!Apifox被投毒,使用者速看:你的Git、SSH、云密钥可能已泄露
java·后端·程序员
Yupureki18 分钟前
《Linux系统编程》18.线程概念与控制
java·linux·服务器·c语言·jvm·c++
运维行者_20 分钟前
金融和电商行业如何使用网络监控保障业务稳定?
开发语言·网络·人工智能·安全·web安全·机器学习·运维开发
帅得不敢出门20 分钟前
Android Framework中调用由java编译成的jar接口
android·java·framework·jar