news 2026/6/10 4:36:25

SpringBoot 开发第三天 学习内容

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SpringBoot 开发第三天 学习内容

一、数据层开发核心

1. 数据源自动管理

  • 核心依赖:spring-boot-starter-jdbc+commons-dbcp2+mysql-connector-java
  • 配置方式:YAML 配置数据库连接信息,通过type指定连接池
  • 自动选择规则:优先 HikariDataSource,其次 Commons DBCP2
  • 核心配置:spring.datasource下配置 username、password、url、driver-class-name、type

2. Druid 数据源配置

  • 引入依赖:druid (1.0.9)+log4j (1.2.15)
  • 核心配置:YAML 中指定type: com.alibaba.druid.pool.DruidDataSource,并配置连接池参数(initialSize、maxActive 等)、监控过滤器
  • 配置类:@Configuration+@ConfigurationProperties(prefix = "spring.datasource")注册 Druid 的 DataSource
  • 运行监控:注册StatViewServlet(访问 /druid,配登录账号)和WebStatFilter(排除静态资源),实现数据源 / SQL/Web 监控

3. 整合 JdbcTemplate

  • 自动配置:JdbcTemplateAutoConfiguration自动注入,直接@Autowired使用
  • 核心用法:调用queryForList等方法执行简单 SQL,返回List<Map<String, Object>>
  • 适用场景:简单的增删改查操作

4. 整合 MyBatis(注解版)

  • 核心依赖:mybatis-spring-boot-starter(1.3.1)
  • 核心步骤:配置 Druid 数据源→建表→创建 JavaBean→编写 @Mapper 接口,用@Select/@Insert/@Delete/@Update注解写 SQL
  • 关键配置:@Options(useGeneratedKeys = true, keyProperty = "pid")实现自增主键回显
  • 驼峰映射:配置类中注册ConfigurationCustomizer,开启mapUnderscoreToCamelCase(true)
  • Mapper 扫描:替代 @Mapper,用@MapperScan("包路径")批量扫描 Mapper 接口

5. 整合 MyBatis(配置文件版)

  • 核心文件:创建 mybatis 核心配置文件sqlMapConfig.xml、映射文件XxxMapper.xml(namespace 对应 Mapper 接口)
  • YAML 配置:mybatis下配置config-location(核心配置文件路径)、mapper-locations(映射文件路径)、type-aliases-package(实体类别名包)
  • 适用场景:复杂 SQL、动态 SQL、联表查询

二、企业信息管理系统实战

1. 项目初始化

  • 引入资源:前端页面原型放入 static/templates 目录
  • 核心依赖:整合 Web、Thymeleaf、MyBatis、Druid、Webjars (jQuery)、devtools 热部署

2. SpringMVC 与 Thymeleaf 配置

  • 配置类:实现WebMvcConfigurer,通过addViewControllers实现请求直接映射到模板页面
  • 拦截器:注册登录拦截器,拦截 /**,放行静态资源、/toLogin、/login
  • 批量扫描:配置类上添加@MapperScan扫描 Mapper 接口

3. 数据库与数据源

  • 建表:创建my_user表(pid 自增,含 username、password、p_addr 等字段)
  • 数据源:复用 Druid 配置,编写 DruidConfig 注册 DataSource

4. 分层开发

  • 配置层:MybatisConfig 开启驼峰映射
  • 数据层:编写 MyUserMapper,注解实现增删改查(含登录查询、主键查询)
  • 服务层:创建 MyUserService 接口,定义增删改查 + 登录相关方法(实现类略)

5. 页面与业务实现

  • 模板引擎:Thymeleaf 引入命名空间,用th:text/th:href/th:each/th:value等标签动态渲染
  • 核心页面:登录页、用户列表页、添加页、修改页,实现页面跳转与数据回显
  • 登录逻辑:Controller 接收账号密码,调用 Service 查询,成功则存入 Session,失败返回提示
  • 核心功能:用户增删改查、登录验证、权限拦截,实现完整的用户管理流程
  • 关键语法:#calendars.format(user.birth,'yyyy-MM-dd')格式化日期、th:if做条件判断、th:each遍历列表
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 21:21:40

Python爬虫代理,选短效IP还是长效IP?

Python爬虫代理是网络数据采集中不可或缺的技术手段&#xff0c;尤其在高频请求、分布式任务或大规模抓取中&#xff0c;代理IP的选择对爬虫运行效率和成功率影响极大。那么问题来了&#xff1a;在实际应用中&#xff0c;应该选择短效IP还是长效IP&#xff1f;本文将结合Python…

作者头像 李华
网站建设 2026/6/9 22:41:43

31-建筑工地安全AI-安全帽与危险行为检测标注实战

&#x1f3d7;️ 引言&#xff1a;AI守护工地安全 建筑行业是高危行业之一。根据国家统计局数据显示&#xff0c;近年来我国建筑业年均发生安全事故超过千起&#xff0c;死亡人数常年位居工矿商贸事故死亡人数前三&#xff0c;其中高处坠落、物体打击、触电和机械伤害是主要致…

作者头像 李华
网站建设 2026/5/31 15:03:00

基于SpringBoot和Vue的在线招标系统的设计与实现

文章目录详细视频演示项目介绍技术介绍功能介绍核心代码系统效果图源码获取详细视频演示 文章底部名片&#xff0c;获取项目的完整演示视频&#xff0c;免费解答技术疑问 项目介绍 基于 SpringBoot 的在线招标系统是一款聚焦招投标全流程数字化管理的平台&#xff0c;整合 “…

作者头像 李华
网站建设 2026/5/24 11:12:33

【jieba词云实战】词云蒙版制作:从图片提取轮廓的三种方法

前篇&#xff1a;【Jieba实战】jieba WordCloud 生成中文词云 想让词云填满一只米老鼠的轮廓&#xff1f;关键在于制作一张合格的蒙版图片。 一、什么是蒙版&#xff1f; ​ WordCloud 的 mask 参数接受一张图片&#xff0c;用它来控制词云的填充区域&#xff1a; 白色像素&a…

作者头像 李华
网站建设 2026/6/10 4:45:22

基于YOLO26的智能道路监测的坑洼分割系统

&#x1f4a1;&#x1f4a1;&#x1f4a1;本文摘要&#xff1a;基于YOLO26的智能道路监测的坑洼分割检测系统&#xff0c;阐述了整个数据制作和训练可视化过程 博主简介 ​ AI小怪兽 | 计算机视觉布道者 | 视觉检测领域创新者 深耕计算机视觉与深度学习领域&#xff0c;专注…

作者头像 李华