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

小结

相关推荐
AI人工智能+电脑小能手2 分钟前
【大白话说Java面试题】【Java基础篇】第24题:Java面向对象有哪些特征
java·开发语言·后端·面试
geovindu19 分钟前
go: Strategy Pattern
开发语言·设计模式·golang·策略模式
276695829223 分钟前
阿里最新acw_sc__v2 分析
开发语言·python·acw_sc__v2·acw_sc__v2逆向·acw_sc__v2算法·acw_sc__v2算法分析·cookie逆向
dog25025 分钟前
圆锥曲线和二次曲线
开发语言·网络·人工智能·算法·php
AI人工智能+电脑小能手32 分钟前
【大白话说Java面试题】【Java基础篇】第25题:JDK1.8的新特性有哪些
java·开发语言·后端·面试
likerhood38 分钟前
SLF4J: Failed to load class “StaticLoggerBinder“ 解决
java·log4j·maven
开发小程序的之朴1 小时前
基于Go语言的企业级CMS系统架构设计与性能分析——以AnQiCMS为例
开发语言·golang·系统架构
早日退休!!!1 小时前
大模型推理瓶颈七层分析模型
java·服务器·数据库
叶小鸡1 小时前
Java 篇-项目实战-天机学堂(从0到1)-day9
java·开发语言
小短腿的代码世界1 小时前
Qt券商接口封装深度解析:统一API设计与多源适配
开发语言·qt·单元测试