SpringBoot 数据访问操作

目录

一.SpringBoot整合Mybatis与Mybatis-Plus

二.SpringBoot切换druid数据源

3.1DRUID配置参数

3.2Druid监控平台


一.SpringBoot整合Mybatis与Mybatis-Plus

步骤:

        1.坐标

         <dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus</artifactId><version>3.1.1</version></dependency>

        注意:mp坐标添加后,mybatis坐标移除(mp坐标包含mybatis)

        2.配置数据源以及mp

先导入德鲁伊数据源

        <!--druid坐标--><dependency><groupId>com.alibaba</groupId><artifactId>druid-spring-boot-starter</artifactId><version>1.2.8</version></dependency>
#数据源
spring:datasource:url: jdbc:mysql://localhost:3306/库?serverTimezone=GMTusername: rootpassword: 密码driver-class-name: com.mysql.cj.jdbc.Drivertype: com.alibaba.druid.pool.DruidDataSourcefilters: stat,wallmybatis:configuration:map-underscore-to-camel-case: true   #自动驼峰映射type-aliases-package: com.apesource.pojo  #起别名mybatis-plus:configuration:map-underscore-to-camel-case: true #自动驼峰映射(默认开启)log-impl: org.apache.ibatis.logging.stdout.StdOutImpl #日志

         3.编写注解配置实体类与关系表映射关系(truncate清空表以及主键)

        @TableName(value = "关联表名称")=========================》修饰在类

        @TableField(value = "关联字段名称")======================》修饰在属性 ​

                exist = "忽略字段"

        @TableLogic(value=“原值”,delval=“修改值”)

        注解参数

        value = “” 未删除的值,默认值为0

        delval = “” 删除后的值,默认值为1

        @TableId(type="指定主键生成策略,默认雪花算法")=============》修饰在属性

         AUTO(0), ​ NONE(1), ​ INPUT(2), ​ ASSIGN_ID(3), ​ ASSIGN_UUID(4);

@NoArgsConstructor//表示无参构造
@AllArgsConstructor//全参构造
@Data//所有属性setget方法以及toString()
@TableName("t_student")
public class Student {@TableId(value = "stu_id",type = IdType.AUTO)private int stuId;@TableField(value = "stu_name")private String stuName;@TableField(value = "stu_nick")private String stuNick;@TableField(value = "stu_hobby")private String stuHobby;@TableLogic(value = "0",delval = "1")private int isdeleted;@TableField(exist = false)private MultipartFile mpf;public Student(String stuName, String stuNick, String stuHobby) {this.stuName = stuName;this.stuNick = stuNick;this.stuHobby = stuHobby;}
}

        4.使用

注入mapper:

@Mapper=====>注册+注入        						   作用:在mapper类上
@MapperScan(value = "mapper所在的包")=>批量注册+注入     作用:在启动类上	

BaseMapper===========》公共的数据访问层

@Mapper
public interface HotelMapper extends BaseMapper<Hotel> {
}

IService/ServiceImp==》公共的业务层

public interface IHotelService extends IService<Hotel> {
}
@Service
public class HotelService extends ServiceImpl<HotelMapper, Hotel> implements IHotelService {
}

二.SpringBoot切换druid数据源

1.导入坐标

        <!--druid坐标--><dependency><groupId>com.alibaba</groupId><artifactId>druid-spring-boot-starter</artifactId><version>1.2.8</version></dependency>

2.做配置

#数据源
spring:datasource:url: jdbc:mysql://localhost:3306/库?serverTimezone=GMTusername: rootpassword: 密码driver-class-name: com.mysql.cj.jdbc.Driver#切换数据源类型type: com.alibaba.druid.pool.DruidDataSource#Druid监控平台配置filters: stat,wallmybatis:configuration:map-underscore-to-camel-case: true   #自动驼峰映射type-aliases-package: com.apesource.pojo  #起别名mybatis-plus:configuration:map-underscore-to-camel-case: true #自动驼峰映射(默认开启)log-impl: org.apache.ibatis.logging.stdout.StdOutImpl #日志

3.1DRUID配置参数

3.2Druid监控平台

filters: stat,wall@Configuration
public class DruidConfig {//1.注入数据源@Bean@ConfigurationProperties(prefix = "spring.datasource")public DataSource dataSource(){return new DruidDataSource();}//2.配置servlet@Beanpublic ServletRegistrationBean registrationBean(){//1.创建servlet注册类ServletRegistrationBean<StatViewServlet>  servletRegistrationBean =  new ServletRegistrationBean<StatViewServlet>();//2.创建制作页面的servletStatViewServlet statViewServlet = new StatViewServlet();//3.绑定servletservletRegistrationBean.setServlet(statViewServlet);servletRegistrationBean.setUrlMappings(Arrays.asList("/druid/*"));//4.参数绑定Map<String,String> maps = new HashMap<String,String>();maps.put(StatViewServlet.PARAM_NAME_USERNAME,"admin");maps.put(StatViewServlet.PARAM_NAME_PASSWORD,"123");maps.put(StatViewServlet.PARAM_NAME_ALLOW,"");//白名单maps.put(StatViewServlet.PARAM_NAME_DENY,"192.168.0.12");//黑名单servletRegistrationBean.setInitParameters(maps);return servletRegistrationBean;}//3.配置filter@Beanpublic FilterRegistrationBean filterRegistrationBean(){FilterRegistrationBean<WebStatFilter> bean = new FilterRegistrationBean<WebStatFilter>();bean.setFilter(new WebStatFilter());//所有请求进行监控处理bean.setUrlPatterns(Arrays.asList("/*"));Map<String, String> initPrams = new HashMap<>();//添加不需要忽略的格式信息initPrams.put(WebStatFilter.PARAM_NAME_EXCLUSIONS, "*.js,*.css,/druid/*");bean.setInitParameters(initPrams);return bean;}}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/50950.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

React系列面试题

大家好&#xff0c;我是有用就点赞&#xff0c;有用就扩散。 1.React的组件间通信都有哪些形式&#xff1f; 父传子&#xff1a;在React中&#xff0c;父组件调用子组件时可以将要传递给子组件的数据添加在子组件的属性中&#xff0c;在子组件中通过props属性进行接收。这个就…

AI伦理困境与隐私保护策略:透明、公平与安全的未来

AI伦理与隐私保护&#xff1a;如何应对挑战并建立治理框架 概述&#xff1a; 随着人工智能的普及&#xff0c;AI伦理和隐私保护问题日益受到关注。本文深入探讨如何在推动AI技术发展的同时&#xff0c;确保透明度、公平性和个人隐私权不受侵犯&#xff0c;为构建负责任的AI未来…

Android ConstraintLayout 约束布局

目录 1&#xff09;ConstraintLayout 约束布局是什么&#xff1f;为什么使用&#xff1f; 2&#xff09;如何使用 3&#xff09;可见性改变后的行为处理 4&#xff09;图形化界面的一些工具介绍 5&#xff09;Chains ( 链 ) 一、ConstraintLayout 约束布局是什么 Constraint…

【无人机】测绘行业新时代

【无人机】测绘行业新时代 无人机测绘主要指的是依托无人机系统为主要的信息接收平台&#xff0c;通过无人机机载遥感信息采集和处理设备&#xff0c;将最终所获取的遥感信息传输到测绘中心&#xff0c;经过数据技术处理&#xff0c;形成立体化的数字模型&#xff0c;以满足行…

JavaScript 输出

JavaScript 不提供任何内建的打印或显示函数。 JavaScript 显示方案 JavaScript 能够以不同方式“显示”数据&#xff1a; 使用 window.alert() 写入警告框使用 document.write() 写入 HTML 输出使用 innerHTML 写入 HTML 元素使用 console.log() 写入浏览器控制台 使用 in…

想要连接稳定的远程控软件吗?这4款软件不要错过

远程控制电脑是一种现代社会高效便捷的办公方式。这种方式可以不论时间不论地点都可以调用到办公电脑里的文件&#xff0c;如果你办公也有这个需求&#xff0c;那就看看我介绍的工具吧。 1.RL远程控制 直通车>>https://www.raylink.live 这个软件非常适合用来进行手机…

Linux常用打包压缩命令

压缩命令应用场景tar大部分使用tar即可。创建&#xff0c;查看&#xff0c;解压&#xff0c;解压到指定目录gzip一般配合其他命令使用zipunzip一般用于解压zip格式的压缩包 1. tar 打包压缩命令 1.1 命令详解 【功能说明】 在Linux系统里&#xff0c;tar是将多个文件打包在…

KEEP_HIERARCHY

KEEP_HIERACHY指示工具保留用户层次结构&#xff0c;以便优化不会 跨越其边界。虽然这有助于布局规划、分析和调试&#xff0c;但它 会抑制优化&#xff0c;导致更大、更慢的设计。 建议&#xff1a;为了避免这些负面影响&#xff0c;请注册一个模块实例的所有输出&#xff0c;…

使用【Easypoi】实现百万数据导出

本文使用easypoi实现百万级数据导出 文章目录 前言一、一般情况下导出二、解决思路三、实现步骤导入依赖重写方法调用实现 结束 前言 下文实现了通过easypoi实现将百万级数据导出 一、一般情况下导出 一般导出流程&#xff08;简单导出&#xff09;&#xff1a; 创建对应的…

智能制造的规划之路线部分

作为新建FAB厂的智能制造负责人&#xff0c;实现智能制造是一个系统工程&#xff0c;需要从战略规划到具体实施的各个层面进行考虑。以下是初稿。。。 1. |明确目标和需求|&#xff1a; - 确定智能制造的目标&#xff0c;比如提高生产效率、降低成本、提升产品质量等。 …

数据库安全综合治理方案(54页PPT)附下载

方案介绍&#xff1a; 数据库安全综合治理方案是一个综合性的策略&#xff0c;旨在确保数据库系统的完整性、保密性和可用性&#xff0c;防止未经授权的访问、数据泄露、篡改及滥用。该方案涉及多个层面&#xff0c;包括访问控制、数据加密、审计与监控、备份与恢复、以及安全…

Dreambooth on Stable Diffusion

Dreambooth on Stable Diffusion 1.DreamBooth: Fine Tuning Text-to-Image Diffusion Models for Subject-Driven Generation 2.[论文简析]DreamBooth: Fine Tuning Text-to-Image Diffusion Models…[2208.12242] 3.sd_dreambooth_extension 4.stable-dreambooth 对3-5张特定…

17.5【C语言】static的补充说明

static &#xff08;静态的) 作用&#xff1a;修饰局部变量&#xff0c;修饰全局变量&#xff0c;修饰函数 对比两段代码 #include <stdio.h> void test() {int a 5;a;printf("%d ", a); } int main() {int i 0;for(i0; i<5; i){test();}return 0; } …

HarmonyOS 质量、测试、上架速浏

1.应用质量要求&#xff1a; 1. 应用体验质量建议: 功能数据完备 功能完备 数据完备 基础体验要求 基础约束 兼容性 稳定性 性能 功耗 安全…

IPython的Bash之舞:%%bash命令全解析

IPython的Bash之舞&#xff1a;%%bash命令全解析 IPython的%%bash魔术命令为Jupyter Notebook用户提供了一种在单元格中直接执行Bash脚本的能力。这个特性特别适用于需要在Notebook中运行系统命令或Bash特定功能的场景。本文将详细介绍如何在IPython中使用%%bash命令&#xff…

reduceByKey 函数详解

reduceByKey 函数详解 实现原理 reduceByKey 函数主要用于处理分布式数据集。它接收两个操作符作为参数&#xff1a; keySelector&#xff1a;这是一个映射函数&#xff0c;用于从输入元素中提取键。 valueReducer&#xff1a;这是另一个函数&#xff0c;用于将具有相同键的…

网格布局 HTML CSS grid layout demo

文章目录 页面效果代码 (HTML CSS)参考 页面效果 代码 (HTML CSS) <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"…

高速传输新体验:探索最新USB-C移动硬盘盒的无限可能

在数字化时代&#xff0c;数据存储的重要性不言而喻&#xff0c;而硬盘盒作为连接外部硬盘与计算机的关键设备&#xff0c;其功能也在不断进化。近年来&#xff0c;随着技术的创新与发展&#xff0c;市场上出现了一种新型硬盘盒——它不仅能安全、高效地存储和传输数据&#xf…

安装VMware Workstation Pro

一、下载 通过百度网盘分享的文件&#xff1a;VMware-workstation-full-16.2.4-2008... 链接&#xff1a;https://pan.baidu.com/s/1mDnFhLQErBlpeX_KjsgtzA 提取码&#xff1a;0bw7 二、安装 &#xff08;1&#xff09;双击exe文件 &#xff08;2&#xff09;安装软件 &…

Docker搭建Flink

Docker搭建Flink环境的步骤&#xff1a; 1. 安装Docker 确保你的系统已经安装了Docker。如果没有安装&#xff0c;可以参考以下命令进行安装&#xff1a; # 对于Ubuntu系统 sudo apt-get update sudo apt-get install docker-ce docker-ce-cli containerd.io # 对于CentOS系…