当前位置: 首页 > news >正文

数据库原理与使用基础教程

数据库原理与使用基础教程

大纲

  1. 数据库基础概述

    • 什么是数据库?
    • 数据库管理系统(DBMS)概述
    • 数据库的类型
    • 数据库模型与结构
  2. 关系型数据库

    • 关系型数据库简介
    • 表(Table)、字段(Field)、记录(Record)
    • SQL基本操作
    • 数据库设计原则
  3. SQL 语言基础

    • SELECT 语句
    • INSERT, UPDATE, DELETE 语句
    • WHERE, ORDER BY, GROUP BY 子句
    • JOIN 操作
    • 子查询
  4. 数据库优化与性能提升

    • 查询优化
    • 使用索引
    • 数据库设计优化
    • 性能监控与调优
  5. 高级数据库功能

    • 事务管理
    • 存储过程与触发器
    • 数据库备份与恢复

第一部分:数据库基础概述

1.1 什么是数据库?

数据库是一个组织化的数据集合,通常包含存储和管理大量结构化数据的功能。简单来说,数据库就像一个数字化的信息库,所有的数据都是按照一定规则存储在数据库中的。

1.2 数据库管理系统(DBMS)概述

数据库管理系统(DBMS,Database Management System)是一种用于创建、管理和操作数据库的软件系统。它允许用户通过结构化查询语言(SQL)来定义、检索、更新和删除数据。常见的DBMS有:

  • MySQL
  • PostgreSQL
  • Oracle
  • Microsoft SQL Server
1.3 数据库的类型

数据库可以根据数据的存储方式和管理方式进行分类,主要有以下几种类型:

  • 关系型数据库(RDBMS):通过表格结构存储数据,支持SQL查询,如MySQL、PostgreSQL、Oracle。
  • 非关系型数据库(NoSQL):适用于存储不规则或半结构化数据,常见有MongoDB、Redis、Cassandra。
1.4 数据库模型与结构

数据库通常遵循一种数据模型来组织数据,最常见的是关系模型。数据库中的数据存储在表格中,表格由行(记录)和列(字段)组成。

图示:数据库表结构
数据库
字段
记录
字段名
数据行

第二部分:关系型数据库

2.1 关系型数据库简介

关系型数据库(RDBMS)是基于关系模型的数据库,数据通过表格的方式进行存储。每个表由多个字段和记录组成。关系型数据库支持SQL(结构化查询语言),通过SQL命令来执行数据操作。

2.2 表(Table)、字段(Field)、记录(Record)
  • 表(Table):数据库中的数据以表格的形式存储。每个表由多行(记录)和多列(字段)组成。
  • 字段(Field):表中的每一列代表一个字段,字段定义了数据的类型和属性。
  • 记录(Record):表中的每一行代表一条记录,记录包含了相关的字段数据。
图示:关系型数据库表结构
graph TDA[表(Table)]A --> B[字段(Field)]A --> C[记录(Record)]B --> D[字段名]C --> E[数据行]E --> F[字段值]
2.3 SQL基本操作

SQL(Structured Query Language,结构化查询语言)是一种用于管理关系型数据库的标准语言。SQL包含若干关键操作,如数据查询、数据插入、数据更新和删除等。

  • 查询(SELECT):用于从数据库中检索数据。
  • 插入(INSERT):用于将新记录插入表中。
  • 更新(UPDATE):用于修改现有记录。
  • 删除(DELETE):用于删除表中的记录。
图示:常见SQL操作
SELECT 查询
FROM 表名
WHERE 条件
返回结果
INSERT 插入数据
INTO 表名
VALUES 数据
UPDATE 更新数据
SET 字段 = 新值
WHERE 条件
DELETE 删除数据
FROM 表名
WHERE 条件
2.4 数据库设计原则

数据库设计是创建一个高效、可扩展和易于管理的数据库的过程。设计良好的数据库可以提高数据的访问效率,减少冗余数据,并确保数据一致性和完整性。以下是一些基本的数据库设计原则:

  • 规范化(Normalization):将数据拆分成多个表,减少冗余。
  • 主键(Primary Key):为每个表指定唯一标识符。
  • 外键(Foreign Key):确保表与表之间的关系。
图示:数据库设计示例
graph TDA[学生表] --> B[主键:学号]A --> C[字段:姓名]A --> D[字段:年龄]E[课程表] --> F[主键:课程ID]E --> G[字段:课程名称]A --> H[外键:课程ID]

第三部分:SQL 语言基础

3.1 SELECT 语句

SELECT 语句是SQL中最常用的语句,用于从一个或多个表中检索数据。SELECT 语句的基本结构如下:

SELECT column1, column2, ...
FROM table_name
WHERE condition;
  • column1, column2:要查询的列(字段)。
  • table_name:要查询的表。
  • condition:查询的条件。
示例:
SELECT name, age
FROM students
WHERE age > 18;

此查询会返回所有年龄大于18岁的学生的名字和年龄。

3.2 INSERT, UPDATE, DELETE 语句
  • INSERT 语句用于插入数据。

    INSERT INTO students (name, age)
    VALUES ('John', 20);
    
  • UPDATE 语句用于更新数据。

    UPDATE students
    SET age = 21
    WHERE name = 'John';
    
  • DELETE 语句用于删除数据。

    DELETE FROM students
    WHERE name = 'John';
    
3.3 WHERE, ORDER BY, GROUP BY 子句
  • WHERE 子句用于指定查询条件。
  • ORDER BY 子句用于对查询结果进行排序。
  • GROUP BY 子句用于将结果集分组,常用于与聚合函数一起使用,如 COUNTSUM 等。
示例:WHERE, ORDER BY, GROUP BY
SELECT name, COUNT(*) AS course_count
FROM students
GROUP BY name
ORDER BY course_count DESC;
3.4 JOIN 操作

JOIN 用于从多个表中检索数据。常见的连接操作有:

  • 内连接(INNER JOIN):返回两个表中匹配的记录。
  • 左连接(LEFT JOIN):返回左表中的所有记录和右表中匹配的记录。
  • 右连接(RIGHT JOIN):返回右表中的所有记录和左表中匹配的记录。
示例:INNER JOIN
SELECT students.name, courses.course_name
FROM students
INNER JOIN course_enrollments ON students.id = course_enrollments.student_id
INNER JOIN courses ON course_enrollments.course_id = courses.id;
3.5 子查询

子查询是查询语句中的查询,通常用于WHEREFROMSELECT中。

示例:子查询
SELECT name
FROM students
WHERE age = (SELECT MAX(age) FROM students);

第四部分:数据库优化与性能提升

4.1 查询优化

数据库性能的提升往往首先体现在查询效率上。优化查询是提高数据库响应速度的关键。以下是几种常见的查询优化技巧:

  1. 使用合适的索引
    索引可以大大提高查询效率,尤其是对于大表中的查询。为经常用于 WHEREORDER BYJOIN 操作的列建立索引。

  2. 避免使用 SELECT *
    使用 SELECT * 会返回表中的所有列,可能包含不需要的字段。应当仅查询必要的列。

  3. 优化连接查询
    在进行连接操作时,应尽量避免进行全表扫描。可以通过优化连接条件,确保连接字段有合适的索引。

  4. 避免不必要的子查询
    子查询可能会导致性能下降,尤其是当子查询返回大量数据时。可以考虑将子查询转换为 JOIN 操作。

图示:查询优化示例
查询
使用索引
仅选择必要字段
优化连接查询
避免不必要的子查询
4.2 使用索引

索引是数据库性能优化的核心之一。通过为表中的列创建索引,可以显著提高查询速度,特别是在进行大数据量的检索时。常见的索引类型包括:

  • 单列索引:为表中的单一列创建索引。
  • 多列索引:为多个列创建索引,适用于需要多个列联合查询的场景。
  • 唯一索引:确保索引列中的值唯一,避免重复数据。
  • 全文索引:对文本数据进行快速检索,通常用于 LIKE 操作中。
示例:创建索引
CREATE INDEX idx_students_name ON students(name);
4.3 数据库设计优化

数据库设计直接影响数据库的性能。良好的数据库设计能够减少冗余,提高数据一致性,同时优化数据访问速度。常见的设计优化策略包括:

  1. 规范化(Normalization)
    规范化是将数据拆分到多个表中,以减少数据冗余。通常遵循的规范化形式有 1NF、2NF、3NF 等。

  2. 反规范化(Denormalization)
    反规范化是为了提高查询性能,将一些数据合并到同一表中。虽然这可能会引入冗余,但在查询频繁的情况下有助于减少连接操作的开销。

  3. 适当的表分区
    对于非常大的表,可以使用分区技术将表数据分割成多个小表,以提高查询效率。

图示:规范化与反规范化
规范化
减少冗余
提高数据一致性
反规范化
提高查询性能
引入冗余
4.4 性能监控与调优

数据库性能的监控和调优是确保数据库高效运行的重要措施。常见的性能监控指标包括查询响应时间、CPU 使用率、内存使用情况等。通过定期监控这些指标,可以及时发现潜在的性能瓶颈,并采取相应的优化措施。

图示:性能监控
性能监控
查询响应时间
CPU 使用率
内存使用情况
磁盘 I/O

第五部分:高级数据库功能

5.1 事务管理

事务是数据库操作中的一个关键概念,它确保一组操作要么完全成功,要么完全失败,从而保证数据的一致性和完整性。事务具有四大特性,即 ACID 特性:

  • 原子性(Atomicity):事务中的操作要么全部完成,要么全部不完成。
  • 一致性(Consistency):事务必须使数据库从一个一致性状态变到另一个一致性状态。
  • 隔离性(Isolation):多个事务同时执行时,彼此之间互不干扰。
  • 持久性(Durability):事务一旦提交,所做的更改就会永久保存。
图示:事务的 ACID 特性
事务
原子性
一致性
隔离性
持久性
5.2 存储过程与触发器
  • 存储过程(Stored Procedure):存储过程是一组预定义的 SQL 语句,可以在数据库中被多次执行。通过存储过程,可以将常用的操作封装起来,减少客户端与数据库的交互次数。

    示例:创建存储过程
    CREATE PROCEDURE GetStudentInfo()
    BEGINSELECT * FROM students;
    END;
    
  • 触发器(Trigger):触发器是由数据库事件(如插入、更新、删除)激活的预定义操作。触发器通常用于自动执行某些操作,如数据验证或日志记录。

    示例:创建触发器
    CREATE TRIGGER AfterStudentInsert
    AFTER INSERT ON students
    FOR EACH ROW
    BEGININSERT INTO audit_log (operation, table_name) VALUES ('INSERT', 'students');
    END;
    
5.3 数据库备份与恢复

数据库备份是保障数据安全的关键措施。通过定期备份,可以确保在数据库出现故障时能够快速恢复数据。备份的方式有多种,如完整备份、增量备份和差异备份。

  • 完整备份:备份整个数据库。
  • 增量备份:仅备份自上次备份以来发生变化的数据。
  • 差异备份:备份自上次完整备份以来的所有变化。
图示:备份与恢复流程
备份
完整备份
增量备份
差异备份
恢复
从备份恢复

结语

本文详细探讨了数据库原理和使用的基础知识,包括数据库的基本概念、关系型数据库的结构与设计、SQL语言的常见操作以及数据库的优化与高级功能。了解和掌握这些内容对于开发高效、可靠的数据库应用至关重要。

如果你对更多高级功能如分布式数据库、数据库安全性等感兴趣,欢迎继续关注本系列文章!

相关文章:

数据库原理与使用基础教程

数据库原理与使用基础教程 大纲 数据库基础概述 什么是数据库?数据库管理系统(DBMS)概述数据库的类型数据库模型与结构 关系型数据库 关系型数据库简介表(Table)、字段(Field)、记录&#xff…...

GCC 与 Clang:两大编译器的全面对比与深度解析!

GCC 与 Clang:两大编译器的全面对比与深度解析!🔥 你是否曾为选择编译器而纠结?GCC 和 Clang 作为 C/C 开发中最主流的编译器,它们各自有什么优势和特点?为什么有人说 Clang 更现代,而 GCC 更强…...

ue5 创建多列StreeView的方法与理解

创建StreeView的多列样式怎么就像是创建单行单列差不多?貌似就是在单行单列中加入了多列widget? 示例代码 DetailTabWidget #pragma once #include "TreeViewItemBase.h"class SDetailTabWidget : public SCompoundWidget {SLATE_BEGIN_ARGS(SDetailTabWidget){…...

GPT-4.5来了

https://chat.xutongbao.top/...

java后端开发day25--阶段项目(二)

(以下内容全部来自上述课程) 1.美化界面 private void initImage() {//路径分两种://1.绝对路径:从盘符开始写的路径 D:\\aaa\\bbb\\ccc.jpg//2.相对路径:从当前项目开始写的路径 aaa\\bbb\\ccc.jpg//添加图片的时…...

【小羊肖恩】小羊杯 Round 2 C+K

题目链接:https://ac.nowcoder.com/acm/contest/100672#question C.是毛毛虫吗? 思路: 其实很简单,假设我们要满足题目所给条件,那么这个毛毛虫最坏情况下肯定是一条如下图所示的无向图 右端省略号为对称图形 &…...

计算机网络——详解TCP三握四挥

文章目录 前言一、三次握手1.1 三次握手流程1.2 tcp为什么需要三次握手建立连接? 二、四次挥手2.1 四次挥手流程2.2 为什么是四次,不是三次?2.3 为什么要等待2msl?2.4 TCP的保活计时器 前言 TCP和UDP是计算机网络结构中运输层的两…...

PHP实现国密SM4算法,银行系统加密算法,JAVA和PHP可相互转换(附完整源码)

最终实现效果:PHP生成加密串,JAVA代码中完成匹配 JAVA SM4库实现效果 /*** 签名** param content 请求报文体* param secret 密钥* return*/public static String sign(String content, String secret) {String charSet "UTF-8";String c…...

DILLEMA:扩散模型+大语言模型,多模态数据增强框架

引言:深度学习模型的鲁棒性测试需要全面且多样化的测试数据。现有的方法通常基于简单的数据增强技术或生成对抗网络,但这些方法在生成真实且多样化的测试数据集方面存在局限性。为了克服这些限制,DILLEMA框架应运而生,旨在通过结合…...

京东web 详情 cfe滑块分析

声明: 本文章中所有内容仅供学习交流使用,不用于其他任何目的,抓包内容、敏感网址、数据接口等均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关! 逆向分析 data response.json() pri…...

【Redis学习】Redis Docker安装,自定义config文件(包括RDB\AOF setup)以及与Spring Boot项目集成

【本文内容】 第1章:通过Docker安装Redis,并自定义config文件以及mount data目录。第2章:介绍Redis持久化到磁盘,有4种方式:RDB / AOF / NONE / RDB AOF。第3章:使用Server自带的redis-cli工具连接。第4章…...

Python 面向对象编程-继承与多态

目录 继承与多态 静态语言 vs 动态语言 小结 继承与多态 在OOP程序设计中,当我们定义一个class的时候,可以从某个现有的class继承,新的class称为子类(Subclass),而被继承的class称为基类、父类或超类&a…...

AcWing 蓝桥杯集训·每日一题2025·5439. 农夫约翰真的种地

5439. 农夫约翰真的种地 题目描述 农夫约翰在他的农场种植了 N N N 个芦笋,编号 ( 1 ∼ N ) (1 \sim N) (1∼N)。 其中,第 i i i 个芦笋的初始高度为 h i h_i hi​,每经过一天高度会增长 a i a_i ai​。 给定一个 ( 0 ∼ N − 1 ) (0…...

如何将 Excel 数据转换为 SQL 脚本:从入门到实战

全文目录: 开篇语? 前言?? 目录?? 什么是 SQL 脚本??? 为什么要将 Excel 转换为 SQL 脚本???? 如何将 Excel 转换为 SQL 脚本 ?? 方法一:使用在线转换工具?? 方法二:通过 Excel VBA 编写脚本?? 方法三…...

0x05 部门功能开发日志技术

准备工作 开发规范 采用restful风格:representational state transfer,表述性状态转换,是一种软件架构风格 REST是风格,是约定方式,约定不是规定,可以打破 描述功能模块通常使用复数形式加s(如…...

塔能物联运维:城市照明极端天气下的“定海神针”

在当今城市快速发展的进程中,城市照明系统的稳定性和可靠性在极端天气条件下愈发受到关注。而塔能物联运维平台的出现,为城市照明在各种复杂环境下的稳定运行提供了强有力的保障,让城市照明在极端天气下也能“稳如泰山”。 城市照明对于保障市…...

Transformer 代码剖析7 - 词元嵌入(TokenEmbedding) (pytorch实现)

一、类定义与继承关系剖析 1.1 代码结构图示 #mermaid-svg-9COHbtmHJhpiroHM {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-9COHbtmHJhpiroHM .error-icon{fill:#552222;}#mermaid-svg-9COHbtmHJhpiroHM .error-t…...

6.6.5 SQL访问控制

文章目录 GRANT授予权限REVOKE回收权限 GRANT授予权限 GRANT语句可以给用户授予权限,基本格式是GRANT 权限 TO 用户。在授权时,WITH GRANT OPTION是可选项,有此句话,被授予权限的用户还能把权限赋给其他用户。 REVOKE回收权限 RE…...

IDEA 使用codeGPT+deepseek

一、环境准备 1、IDEA 版本要求 安装之前确保 IDEA 处于 2023.x 及以上的较新版本。 2、Python 环境 安装 Python 3.8 或更高版本 为了确保 DeepSeek 助手能够顺利运行,您需要在操作系统中预先配置 Python 环境。具体来说,您需要安装 Python 3.8 或更高…...

React + TypeScript 实现 SQL 脚本生成全栈实践

React TypeScript 实现数据模型驱动 SQL 脚本生成全栈实践 引言:数据模型与 SQL 的桥梁革命 在现代化全栈开发中,数据模型与数据库的精准映射已成为提升开发效率的关键。传统手动编写 SQL 脚本的方式存在模式漂移风险高(Schema Drift&#…...

用DeepSeek生成批量删除处理 PDF第一页工具

安装依赖库 在运行程序之前,请确保安装所需的库: pip install pymupdf python-docx Python 程序代码 import os import fitz # PyMuPDF from docx import Documentdef delete_pdf_first_page(input_path, output_path):"""删除 PDF…...

三个小时学完vue3(一)

Vue3 之前就学过一些&#xff0c;不过用的比较少&#xff0c;基本忘完了/(ㄒoㄒ)/~~ 跟着B站视频迅速回忆一下 创建一个Vue 3 应用 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport&…...

netty如何处理粘包半包

文章目录 NIO中存在问题粘包半包滑动窗口MSS 限制Nagle 算法 解决方案 NIO中存在问题 粘包 现象&#xff0c;发送 abc def&#xff0c;接收 abcdef原因 应用层&#xff1a;接收方 ByteBuf 设置太大&#xff08;Netty 默认 1024&#xff09;滑动窗口&#xff1a;假设发送方 25…...

最好Wordpree+Apache+PHP安装教程

前提需要 PHP的安装最少需要7.4以上Mysql的安装&#xff0c;直接默认最新版就行APache服务器&#xff08;HTTP服务器&#xff0c;只有用这个你的软件才能在服务器上运行&#xff09; 安装apache 安装 sudo apt install apache2查看防火墙 sudo ufw app list如果有 Apache那…...

0x02 js、Vue、Ajax

文章目录 js核心概念js脚本引入html的方式基础语法事件监听 Vuevue简介v-forv-bindv-if&v-showv-model&v-on Ajax js 核心概念 JavaScript&#xff1a;是一门跨平台、面向对象的脚本语言&#xff0c;用来控制网页行为实现交互效果&#xff0c;由ECMAScript、BOM、DOM…...

如何使用Docker搭建哪吒监控面板程序

哪吒监控(Nezha Monitoring)是一款自托管、轻量级的服务器和网站监控及运维工具,旨在为用户提供实时性能监控、故障告警及自动化运维能力。 文档地址:https://nezha.wiki/ 本章教程,使用Docker方式安装哪吒监控面板,在此之前,你需要提前安装好Docker. 我当前使用的操作系…...

智能图像处理平台:图片管理

接着我们讲图片管理&#xff0c;先实现图片基础的增删改查&#xff0c;再去考虑图像处理。 主要是&#xff0c;我们需要完成查询时&#xff0c;查询的图片的上传者的角色等级小于等于我们当前登陆账号。 后端controller&#xff1a; package com.llpp.controller;import cn.…...

如何使用Docker一键本地化部署LibrePhotos搭建私有云相册

文章目录 前言1.关于LibrePhotos2.本地部署LibrePhotos3.LibrePhotos简单使用4. 安装内网穿透5.配置LibrePhotos公网地址6. 配置固定公网地址 前言 你是不是也经常对着手机里那一堆珍贵的照片发愁&#xff0c;心里想着&#xff1a;‘这要是被谁偷偷看了可咋办&#xff1f;’别…...

删除idea recent projects 记录

1、退出idea&#xff08;一定要全部退出idea&#xff0c;要不然删除后&#xff0c;idea一退出&#xff0c;又保存上了&#xff09; 2、进入 C:\Users\Administrator\AppData\Roaming\JetBrains\IntelliJIdea2024.1\options 目录 根据不同的版本号 IntelliJIdea2024.1 这个地方…...

基因组突变数据分析-ClinVar数据库

探序基因肿瘤研究院 数据库简介&#xff1a;ClinVar是一个免费访问的公共数据库&#xff0c;记录了人类变异和表型之间的关系&#xff0c;并提供了支持性证据&#xff08;supporting evidence&#xff09;。ClinVar提供的变异临床意义&#xff08;clinical significance&#…...

windows 下 使用Python OpenCV针对 压缩的tiff 图像进行解压缩 并转换成多张jpeg 图像

文章大纲 Tif/Tiff 图像简介tif 后缀的文件中为什么可以嵌入多张图片Tif 图像 与 jpg 图像转换的要点参考使用的 GitHub 仓库链接tifffile 库的功能与其他库的区别代码实现 基于 tifffile参考文献Tif/Tiff 图像简介 TIFF(Tagged Image File Format)是一种灵活且可适应的文件…...

小皮网站搭建

前提&#xff1a;小皮的安装下载 1、在www目录下创建一个新的文件夹&#xff0c;用来存放网站源码&#xff1b; 2、安装数据库管理工具phpMyadmin 3、新建数据表 添加字段 4、创建网站 5、前端的登录代码 注册 后端php 网页展示 登录成功跳转welcome.php...

Java8面试

Java 8 有哪些新特性? &#x1f40e;Java 8五大神装特性&#x1f40e; Lambda表达式&#xff08;魔法调料&#xff09; 曼波觉得像速食魔法咒语&#xff01;(๑✧◡✧๑) // 传统写法&#xff08;像冗长菜谱&#xff09; new Thread(new Runnable() {public void run() {Syst…...

一个基于C# Winform开源免费的通用快速开发框架,内置完整的权限架构!

前言 今天大姚给大家分享一个基于C# Winform开源免费&#xff08;GPL-2.0开源协议&#xff09;的通用快速开发框架&#xff0c;内置完整的权限架构&#xff1a;WinformDevFramework。 项目介绍 WinformDevFramework是一个基于C# Winform开源免费&#xff08;GPL-2.0开源协议…...

2025年度福建省职业院校技能大赛高职组“信息安全管理与评估”赛项规程样题模块二

模块二 网络安全事件响应、数字取证调查、应用程序安全 竞赛项目赛题 本文件为信息安全管理与评估项目竞赛-第二阶段样题&#xff0c;内容包括&#xff1a;网络安全事件响应、数字取证调查。 本次比赛时间为90分钟。 介绍 竞赛有固定的开始和结束时间&#xff0c;参赛队伍必须…...

【朝夕教育】《鸿蒙原生应用开发从零基础到多实战》005-TypeScript 中的枚举

标题详情作者简介愚公搬代码头衔华为云特约编辑&#xff0c;华为云云享专家&#xff0c;华为开发者专家&#xff0c;华为产品云测专家&#xff0c;CSDN博客专家&#xff0c;CSDN商业化专家&#xff0c;阿里云专家博主&#xff0c;阿里云签约作者&#xff0c;腾讯云优秀博主&…...

使用create_sql_query_chain工具根据自然语言问题生成SQL查询,踩坑版

1. 开启调试模式 from langchain import debugdebug True # 启用调试模式说明&#xff1a; 这里从 langchain 库中导入了一个名为 debug 的变量&#xff08;或模块&#xff09;&#xff0c;然后将它设置为 True。这通常用来启用调试模式&#xff0c;方便开发者在程序运行时看…...

DeepSeek本地部署+自主开发对话Web应用

文章目录 引言前端部分核心页面DeepSeek.vueMyModal.vue 后端部分WebSocketConfig 配置类AbstractDeepSeekToolDeepSeekWebSocketHandler 数据库设计总结 引言 最近DeepSeep横空出世&#xff0c;在全球内掀起一股热潮&#xff0c;到处都是满血大模型接入的应用&#xff0c;但这…...

【Springboot】解决问题 o.s.web.servlet.PageNotFound : No mapping for *

使用 cursor 进行老项目更新为 springboot 的 web 项目&#xff0c;发生了奇怪的问题&#xff0c;就是 html 文件访问正常&#xff0c;但是静态文件就是 404 检查了各种配置&#xff0c;各种比较&#xff0c;各种调试&#xff0c;最后放弃时候&#xff0c;清理没用的配置文件&…...

微信小程序点击按钮,将图片下载到本地

前言&#xff1a; 最近在公司完成一个小程序的时候需要实现一个功能&#xff1a;点击按钮获取用户相册权限&#xff0c;将图片下载到用户本地相册&#xff0c;经过了好几次的尝试最终算是实现了。将总结的经验在这里分享给小伙伴们。 实现方式&#xff1a; //.wxml文件 <…...

解锁网络防御新思维:D3FEND 五大策略如何对抗 ATTCK

D3FEND 简介 背景介绍 2021年6月22日&#xff08;美国时间&#xff09;&#xff0c;美国MITRE公司正式发布了D3FEND——一个网络安全对策知识图谱。该项目由美国国家安全局&#xff08;NSA&#xff09;资助&#xff0c;并由MITRE的国家安全工程中心&#xff08;NSEC&#xff…...

架构案例:从初创互联网公司到分布式存储与反应式编程框架的架构设计

文章目录 引言一、初创互联网公司架构演化案例1. 万级日订单级别架构2. 十万级日订单级别架构3. 百万级日订单级别架构 二、分布式存储系统 Doris 架构案例三、反应式编程框架架构案例总结 引言 分布式架构 今天我们将探讨三种不同类型的架构案例&#xff0c;分别探讨 一个初…...

Redis数据结构-List列表

1.List列表 列表类型适用于存储多个有序的字符串&#xff08;这里的有序指的是强调数据排列顺序的重要&#xff0c;不是升序降序的意思&#xff09;&#xff0c;列表中的每个字符串称为元素&#xff08;element&#xff09;&#xff0c;一个列表最多可以存储2^32-1个元素。在R…...

开启AI短剧新纪元!SkyReels-V1/A1双剑合璧!昆仑万维开源首个面向AI短剧的视频生成模型

论文链接&#xff1a;https://arxiv.org/abs/2502.10841 项目链接&#xff1a;https://skyworkai.github.io/skyreels-a1.github.io/ Demo链接&#xff1a;https://www.skyreels.ai/ 开源地址&#xff1a;https://github.com/SkyworkAI/SkyReels-A1 https://github.com/Skywork…...

mac安装环境

minconda https://docs.anaconda.net.cn/miniconda/install/ 注意在下载下来应该有100多兆&#xff0c;太大了应该是完整版&#xff0c;我们不需要 jdk 镜像网站下载设置环境变量&#xff1a; 终端&#xff1a;sudo vim ~/.zshrc # JDK Config JAVA_HOME/Library/Java/Java…...

js加密之延伸requestAnimationFrame

简言 上篇文章有提到requestAnimationFrame,只是随笔带过。这篇文章就着重研究一下requestAnimationFrame的运用&#xff0c;以及实际作用。还有关于在js加密技术中的落地实现可行性。 功能说明 小声说一下,做开发的同学一定要学会翻官方文档,我这里直接引用一段官方介绍。 …...

SpringBoot @Value 注解使用

Value 注解用于将配置文件中的属性值注入到Spring管理的Bean中。 1. 基本用法 Value 可以直接注入配置文件中的属性值。 配置文件 (application.properties 或 application.yml) 配置文件定义需要注入的数据。 consumer:username: lisiage: 23hobby: sing,read,sleepsubje…...

JavaFunction的使用

一、基础概念与核心方法 ​定义与作用​ Function<T, R> 是一个函数式接口&#xff0c;接收类型为 T 的输入参数&#xff0c;返回类型为 R 的结果。其核心方法为 apply(T t)。例如&#xff0c;将字符串转换为整数长度&#xff1a; java Function<String, Integer>…...

TVbox蜂蜜影视:智能电视观影新选择,简洁界面与强大功能兼具

蜂蜜影视是一款基于猫影视开源项目 CatVodTVJarLoader 开发的智能电视软件&#xff0c;专为追求简洁与高效观影体验的用户设计。该软件从零开始编写&#xff0c;界面清爽&#xff0c;操作流畅&#xff0c;特别适合在智能电视上使用。其最大的亮点在于能够自动跳过失效的播放地址…...

Python基于交互注意力的深度时空网络融合多源信息的剩余寿命预测方法

基于交互注意力的深度时空网络融合多源信息的剩余寿命预测方法 一、方法框架设计 本方法的核心思想是通过交互注意力机制动态捕捉多源数据间的跨模态关联&#xff0c;并结合深度时空网络建模序列的时空退化特征。 1. 多源特征编码器 输入&#xff1a;传感器数据、工况参数、…...