数据库原理(1)
第一章 概论
一、基本概念
数据(Data)是数据库中存储的基本对象,描述事物的符号记录。例如学生的学号、姓名等信息都是数据。
数据库(Database,DB)长期存储在计算机内、有组织的、可共享的大量数据的集合。像学校的教务管理系统中的学生信息库。
数据库管理系统(Database Management System,DBMS)位于用户与操作系统之间的一层数据管理软件。它的主要功能包括数据定义、数据操纵、数据库的运行管理、数据库的建立和维护等。例如 MySQL、Oracle 等都是 DBMS。
数据库系统(Database System,DBS)由数据库、数据库管理系统(及其应用开发工具)、数据库管理员(DBA)和用户构成。
二、数据模型分类及三要素
1.数据模型分类
概念模型:按用户的观点对数据和信息建模,主要用于数据库设计。例如 E - R 模型(实体 - 关系模型)。
逻辑模型:按计算机系统的观点对数据建模,包括层次模型、网状模型、关系模型等。关系模型是目前最常用的逻辑模型,如在 MySQL 中使用关系模型来组织数据。
物理模型:描述数据在存储介质上的组织结构,与具体的 DBMS 和硬件有关。
2.数据三大模型
层次模型:像一棵树一样,有根节点、父节点和子节点,节点之间是一对多的联系。例如一个公司的部门组织架构可以用层次模型表示,公司总部是根节点,下设各个部门是子节点。树状结构
网状模型:节点之间可以是多对多的联系,其结构像网一样。例如交通网络中,各个城市(节点)之间有多条道路(联系)相连。网状结构
关系模型:以二维表的形式来组织数据,表中的一行称为一个元组,一列称为一个属性。例如学生表(学号,姓名,年龄,专业)就是一个关系模型。二维表
3.数据模型的三要素
数据结构:描述数据库的组成对象以及对象之间的联系。例如关系模型中的关系(二维表)结构。
数据操作:对数据库中各种对象(型)的实例(值)允许执行的操作的集合,包括查询和更新(插入、删除、修改)等操作。
数据的完整性约束条件:一组完整性规则的集合。例如在关系模型中,实体完整性要求关系的主键不能为空值。
三、三级模式与二级映像
三级模式
外模式(External Schema):是数据库用户(包括应用程序员和最终用户)能够看见和使用的局部数据的逻辑结构和特征的描述,是数据库用户的数据视图,是与某一应用有关的数据的逻辑表示。是用户与数据库系统的接口,是用户用到的那部分数据的描述。例如,在学校的教务管理系统中,教师查询学生成绩的界面所涉及的数据结构就是一种外模式。局部逻辑
模式(Schema):也称逻辑模式,是数据库中全体数据的逻辑结构和特征的描述,是所有用户的公共数据视图。它是数据库系统模式结构的中间层,既不涉及数据的物理存储细节和硬件环境,也与具体的应用程序、开发工具及高级程序设计语言无关。全局逻辑
内模式(Internal Schema):也称存储模式,是数据物理结构和存储方式的描述,是数据在数据库内部的表示方式。例如数据在磁盘上的存储方式,如顺序存储、hash法,是否加密和压缩等。物理结构
二级映像
外模式 / 模式映像:定义了外模式与模式之间的对应关系。当模式改变时(例如增加新的关系、改变关系的属性等),由数据库管理员对各个外模式 / 模式的映像做相应改变,可以使外模式保持不变。应用程序是依据外模式编写的,从而应用程序不必修改,保证了数据的逻辑独立性。
模式 / 内模式映像:定义了模式与内模式之间的对应关系。当数据库的内模式(例如存储结构、存储方式等)发生改变时,由数据库管理员对模式 / 内模式映像做相应改变,可以使模式保持不变,从而应用程序也不必改变,保证了数据的物理独立性。
第二章 关系数据库
一、关系代数计算
选择(σ)从关系中选择满足给定条件的元组。例如,有学生关系表 Student(学号,姓名,年龄,性别),要选择年龄大于 20 岁的学生,关系代数表达式为:σ 年龄 > 20 (Student)。
投影(π)从关系中选择若干属性列组成新的关系。例如,从学生关系表 Student 中只选择学号和姓名这两个属性,关系代数表达式为:π 学号,姓名 (Student)。
自然连接(⨝)是一种特殊的等值连接,它要求两个关系中进行比较的分量必须是相同的属性组,并且在结果中把重复的属性列去掉。例如有学生关系表 Student(学号,姓名,专业)和选课关系表 CourseSelection(学号,课程号,成绩),要得到学生的学号、姓名、课程号和成绩的关系,关系代数表达式为:Student ⨝ CourseSelection。
除(÷)设关系 R (X,Y) 和 S (Y),其中 X、Y 可以是单个属性或属性集。R÷S 的结果是一个关系,其属性为 X,元组是满足以下条件的 X 值:在 R 中与该 X 值对应的 Y 值的集合包含 S 中的所有 Y 值。例如,有供应商关系表 Supplier(供应商编号,供应零件编号)和零件关系表 Part(零件编号),要找出能供应所有零件的供应商编号,就可能用到除运算。
并(∪)、交(∩)、差( - )、笛卡尔积(×)
并:设关系 R 和 S 具有相同的关系模式,R∪S 是由属于 R 或属于 S 的元组组成的集合。例如有两个关系 R(1,2)和 S(2,3),R∪S ={(1,2),(2,3)}。
交:设关系 R 和 S 具有相同的关系模式,R∩S 是由既属于 R 又属于 S 的元组组成的集合。例如 R(1,2)和 S(2,3),R∩S ={(2,3)}。
差:设关系 R 和 S 具有相同的关系模式,R - S 是由属于 R 但不属于 S 的元组组成的集合。例如 R(1,2)和 S(2,3),R - S ={(1,2)}。
笛卡尔积:设关系 R 为 m 元关系,有 k1 个元组;关系 S 为 n 元关系,有 k2 个元组。则 R×S 是一个 m + n 元关系,有 k1×k2 个元组。例如 R(a,b),S(c,d),R×S=(a,b,c,d)。
比较运算符:如大于(>)、小于(<)、等于(=)等,用于条件判断。
逻辑运算符:与(∧)、或(∨)、非(¬),用于组合多个条件。
二、根据查询要求写出关系代数表达式
仔细分析查询需求,确定需要使用的关系代数运算。
按照运算顺序准确写出表达式。例如,要查询选修了课程号为 'C1' 且成绩大于 80 分的学生的学号和姓名,假设学生关系为 Student(学号,姓名),选课关系为 CourseSelection(学号,课程号,成绩),关系代数表达式为:π 学号,姓名 (σ 课程号 = 'C1'∧成绩> 80 (Student ⨝ CourseSelection))。
第三章 SQL 语言
一、SQL 语言的基本功能
数据定义(DDL)用于定义数据库、表、视图、索引等数据库对象。
CREATE:用于创建数据库、表、索引等数据库对象。例如创建一个学生表:CREATE TABLE student (student_id INT PRIMARY KEY, name VARCHAR(50), age INT);
ALTER:修改数据库对象的结构。如给学生表增加一个性别列:ALTER TABLE student ADD COLUMN gender VARCHAR(10);
DROP:删除数据库对象。如删除一个表:DROP TABLE student;
数据操纵(DML)包括对数据库中数据的插入(INSERT)、更新(UPDATE)、删除(DELETE)操作
INSERT:向表中插入数据。例如向学生表插入一条记录:INSERT INTO student (student_id, name, age) VALUES (1, 'John', 20);
UPDATE:更新表中的数据。如将学号为1的学生年龄改为21:UPDATE student SET age = 21 WHERE student_id = 1;
DELETE:从表中删除数据。如删除学号为1的学生记录:DELETE FROM student WHERE student_id = 1;
数据查询(DQL)是 SQL 语言的核心功能,用于从数据库中查询数据。
SELECT:是SQL中最常用的语句,用于从一个或多个表中查询数据。例如查询所有学生的姓名和年龄:SELECT name, age FROM student;
数据控制(DCL)用于控制用户对数据库的访问权限,包括授权(GRANT)和收回权限(REVOKE)等操作。
GRANT:授予用户权限。如授予用户user1对学生表的查询权限:GRANT SELECT ON student TO user1;
REVOKE:收回用户权限。如收回用户user1对学生表的查询权限:REVOKE SELECT ON student FROM user1;
二、定义数据库、定义表的 SQL 命令
定义数据库 基本语法:CREATE DATABASE database_name; 其中 database_name 是要创建的数据库名称。例如 CREATE DATABASE school;
定义表基本语法:CREATE TABLE table_name (column1 datatype [constraint],column2 datatype [constraint],...); 例如 CREATE TABLE course (课程号 VARCHAR (10) PRIMARY KEY, 课程名 VARCHAR (50), 学分 INT); 这里的 PRIMARY KEY 是约束条件,表示课程号是主键。还可以定义外键约束,如 CREATE TABLE CourseSelection (学号 VARCHAR (10), 课程号 VARCHAR (10), 成绩 INT,FOREIGN KEY (学号) REFERENCES student (学号),FOREIGN KEY (课程号) REFERENCES course (课程号));
三、基本查询、条件查询、分组、排序、聚集函数、top 子句
基本查询:使用 SELECT 语句查询表中的所有数据,如 SELECT * FROM table_name。
条件查询:在 SELECT 语句中使用 WHERE 子句来指定查询条件。例如,查询年龄大于 20 岁的学生:SELECT * FROM student WHERE 年龄 > 20。对于空值的判断,可以使用 IS NULL 或 IS NOT NULL。例如,查询没有成绩的选课记录:SELECT * FROM CourseSelection WHERE 成绩 IS NULL。
分组(GROUP BY):按照指定的列对查询结果进行分组。例如,查询每个专业的学生人数:SELECT COUNT (*), 专业 FROM student GROUP BY 专业。
排序(ORDER BY):使用 ORDER BY 子句对查询结果进行升序(ASC,默认)或降序(DESC)排序。例如,查询学生信息并按照年龄从小到大排序:SELECT * FROM student ORDER BY 年龄 ASC。
聚集函数:如 COUNT 计算行数、SUM 计算总和、AVG 计算平均值、MAX 计算最大值、MIN 计算最小值等。例如,计算学生的平均年龄:SELECT AVG (年龄) FROM student。
top 子句:在不同的 DBMS 中有不同的实现方式,用于限制查询结果的行数。例如在 SQL Server 中:SELECT TOP 10 * FROM student; 在 MySQL 中:SELECT * FROM student LIMIT 10。
四、嵌套查询、连接查询
嵌套查询是指将一个查询块嵌套在另一个查询块的 WHERE 子句或 HAVING 子句中的查询。例如,查询选修了课程名为 ' 数学 ' 的学生学号,假设课程表为 course(课程号,课程名),选课表为 CourseSelection(学号,课程号),可以先查询出 ' 数学 ' 课程的课程号,再查询选修该课程号的学生学号。内层查询:SELECT 课程号 FROM course WHERE 课程名 = ' 数学 '; 外层查询:SELECT 学号 FROM CourseSelection WHERE 课程号 =(SELECT 课程号 FROM course WHERE 课程名 = ' 数学 ');
连接查询用于将多个表中的数据按照一定的条件组合在一起。例如内连接(INNER JOIN):SELECT student. 学号,student. 姓名,course. 课程名,CourseSelection. 成绩 FROM student INNER JOIN CourseSelection ON student. 学号 = CourseSelection. 学号 INNER JOIN course ON CourseSelection. 课程号 = course. 课程号;还可以有左连接(LEFT JOIN)、右连接(RIGHT JOIN)、全连接(FULL JOIN)等不同类型的连接查询。
五、插入新记录、更新数据、删除数据
插入新记录使用 INSERT INTO 语句。例如,INSERT INTO student (学号,姓名,年龄) VALUES ('001',' 张三 ',20); 如果要插入所有列的值,可以省略列名,如 INSERT INTO student VALUES ('001',' 张三 ',20);
更新数据使用 UPDATE 语句。例如,UPDATE student SET 年龄 = 21 WHERE 学号 ='001';
删除数据使用 DELETE FROM 语句。例如,DELETE FROM student WHERE 学号 ='001';
六、索引的建立语句、分类、作用
建立语句基本语法:CREATE [UNIQUE] INDEX index_name ON table_name (column1 [ASC|DESC],column2 [ASC|DESC],...); 其中 UNIQUE 表示创建唯一索引,index_name 是索引名称,table_name 是要创建索引的表名,column1、column2 等是要创建索引的列名,可以指定升序(ASC)或降序(DESC)排列。例如,CREATE INDEX idx_name ON student (姓名);
分类
聚集索引(clustered):该索引中键值的逻辑顺序决定了表中相应行的物理顺序。一个表只能有一个聚集索引。
非聚集索引(non - clustered):索引的逻辑顺序与表中行的物理顺序不同。一个表可以有多个非聚集索引。
作用提高查询速度,通过快速定位数据的物理位置或逻辑位置,减少查询时的磁盘 I/O 操作。
七、视图的建立 SQL 命令
基本语法:CREATE VIEW view_name AS SELECT column1,column2,... FROM table_name WHERE condition; 例如,CREATE VIEW young_student AS SELECT * FROM student WHERE 年龄 < 20; 视图是一个虚拟表,它是从一个或多个基本表(或视图)导出的表,视图本身不存储数据,数据仍然存储在基本表中。
第四章 数据库安全性
一、安全性基本定义
数据库安全性是指保护数据库以防止不合法的使用所造成的数据泄露、更改或破坏。例如,防止非法用户登录数据库系统查看或修改敏感数据,如学生的成绩信息、用户的银行账户信息等。
二、自主存取控制
授权(GRANT)用于将对数据库对象(如表、视图等)的操作权限授予用户或角色。例如,授予用户 user1 对学生表 student 的查询权限:GRANT SELECT ON student TO user1; 还可以授予多个权限,如 GRANT SELECT,INSERT ON student TO user1;
收回权限(REVOKE)与授权操作相反,用于收回用户或角色对数据库对象的操作权限。例如,收回用户 user1 对学生表 student 的查询权限:REVOKE SELECT ON student FROM user1; 在授权和收回权限的语句中,直接在 ON 后面跟表名或视图名,不需要写 table 或者 view 字样。
相关文章:
数据库原理(1)
第一章 概论 一、基本概念 数据(Data)是数据库中存储的基本对象,描述事物的符号记录。例如学生的学号、姓名等信息都是数据。 数据库(Database,DB)长期存储在计算机内、有组织的、可共享的大量数据的集合。…...
SQL盲注问题深度解析与防范策略
引言 在当今互联网时代,Web应用程序的安全性是重中之重。SQL注入作为一种常见且极具威胁性的攻击手段,而其中的SQL盲注更是因其隐蔽性强、难以察觉而备受关注。攻击者借助SQL盲注,在无法直接获取数据库返回结果的情况下,通过精心构造特殊的SQL语句,利用页面的不同响应来逐…...
Android JIT( ART即时编译器),Just In Time Compiler,即时编译技术
Android JIT( ART即时编译器),Just In Time Compiler,即时编译技术 Android Runtime (ART) 包含一个具备代码分析功能的即时 (JIT) 编译器,该编译器可以在 Android 应用运行时持续提高其性能。JIT是Just In Time Compiler…...
当自动驾驶遇上“安全驾校”:NVIDIA如何用技术给无人驾驶赋能?
自动驾驶技术的商业化落地,核心在于能否通过严苛的安全验证。国内的汽车企业其实也在做自动驾驶,但是吧,基本都在L2级别。换句话说就是在应急时刻内,还是需要人来辅助驾驶,AI驾驶只是决策层,并不能完全掌握…...
Unity中数据储存
在Unity项目开发中,会有很多数据,有需要保存到本地的数据,也有直接保存在缓存中的临时数据,一般为了方便整个项目框架中各个地方能调用需要的数据,因此都会实现一个数据工具或者叫数据管理类,用来管理项目中所有的数据。 首先保存在缓存中的数据,比如用户信息,我们只需…...
【C++11】可变参数模板
前言: 上文我们学到右值引用及其移动语义,学习到了C11中对性能提升对重要的更新之一。C11进阶之路:右值引用和移动语义,让代码跑得更快!-CSDN博客 本文我们来讲讲,C11的下一个新语法:可变参数模…...
c语言知识整理
一 数据的存储 对于整形的存储 无论是正负在存储中都是使用补码进行存储的 那个一个数字的补码在转换正负时不同的 对于存储中 首位一定是符号位 如果是0 那么是正数 如果是1 那么是负数 (32位 除符号位 缺少的位数使用0补齐) 如果是正数 …...
算法习题-力扣446周赛题解
算法可以调度思维,让程序员的思维发散,找到更好的解决方案。 第一题:执行指令后的得分 题目: 给你两个数组:instructions 和 values,数组的长度均为 n。你需要根据以下规则模拟一个过程: 从下标…...
基于共享上下文和自主协作的 RD Agent 生态系统
在llmangentmcp这个框架中: LLM: 依然是智能体的“大脑”,赋予它们理解、推理、生成和规划的能力,并且也用于处理和利用共享上下文。Agent: 具备特定 R&D 职能的自主单元,它们感知共享上下文࿰…...
Operating System 实验五 进程管理编程实验
实验目标: 写个多线程的程序,重现竞争条件,并通过信号量或者互斥量,解决临界区问题某工厂有两个生产车间和一个装配车间,两个生产车间分别生产A、B两种零件,装配车间的任务是把A、B两种零件组装成产品。两个生产车间每生产一个零件后,都要分别把它们送到装配车间的货架F…...
Deep Reinforcement learning for real autonomous mobile robot navigation
https://www.youtube.com/watch?vKyA2uTIQfxw AI Learns to Park - Deep Reinforcement Learning https://www.youtube.com/watch?vVMp6pq6_QjI Q Learning simply explained | SARSA and Q-Learning Explanation https://www.youtube.com/watch?vMI8ByADM…...
计算机网络 | 应用层(4)--DNS:因特网的目录服务
💓个人主页:mooridy-CSDN博客 💓文章专栏:《计算机网络:自定向下方法》 大纲式阅读笔记_mooridy的博客-CSDN博客 🌹关注我,和我一起学习更多计算机网络的知识 🔝🔝 目录 …...
WPF核心技术解析与使用示例
WPF核心技术解析与使用示例 一、依赖属性(Dependency Property)详解 1. 依赖属性基础 核心概念: 依赖属性是WPF实现数据绑定、样式、动画等特性的基础通过属性系统实现高效的内存管理和值继承标准定义模式: public class MyControl : Control {// 1. 定义…...
JVM运行机制全景图:从源码到执行的全过程
JVM运行机制全景图:从源码到执行的全过程 引言:你真的了解 Java 是怎么跑起来的吗? 许多开发者写完 Java 代码之后,就交给编译器和运行时去“神奇”地执行了。但你有没有想过,一段 .java 文件是如何一步步变成可运行的程序?今天,我们就从 源码 ➝ 字节码 ➝ 类加载 ➝…...
使用 AFL++ 对 IoT 二进制文件进行模糊测试 - 第二部分
在上一部分中,我们研究了如何使用 AFL++ 对简单的物联网二进制文件进行模糊测试。这些程序接受来自文件的输入,并且易于模糊测试。 在本文中,我们将研究套接字二进制文件。使用套接字进行网络通信的模糊测试二进制文件与使用基于文件 I/O 的模糊测试二进制文件不同。Vanill…...
在华为云平台上使用 MQTT 协议:构建高效可靠的物联网通信
🌐 在华为云平台上使用 MQTT 协议:构建高效可靠的物联网通信 随着物联网(IoT)技术的发展,设备间的高效通信变得尤为重要。MQTT(Message Queuing Telemetry Transport)作为一种轻量级的消息传输…...
基于STM32的物流搬运机器人
功能:智能循迹、定距夹取、颜色切换、自动跟随、自动避障、声音夹取、蓝牙遥控、手柄遥控、颜色识别夹取、循迹避障、循迹定距…… 包含内容:完整源码、使用手册、原理图、视频演示、PPT、论文参考、其余资料 资料只私聊...
H.264/AVC标准主流开源编解码器编译说明
An artisan must first sharpen his tools if he is to do his work well. 工欲善其事,必先利其器. 前言 想研究和学习H.264/AVC视频编解码标准的入门的伙伴们,不论是学术研究还是工程应用都离不开对源码的分析,因此首要工作是对各类编解码器进行编译,本文针对主流的一些符…...
Xilinx FPGA支持的FLASH型号汇总
以博主这些年的FPGA开发使用经验来看,FPGA开发的主流还是以Xilinx FPGA为主,贸易战关税战打了这么多年,我们做研发的也不可避免的要涉及一些国产替代的工作;这里把Xilinx FPGA官方支持的各类(国产和非国产)…...
【C++ 类和数据抽象】消息处理示例(1):从设计模式到实战应用
目录 一、数据抽象概述 二、消息处理的核心概念 2.1 什么是消息处理? 2.2 消息处理的核心目标 三、基于设计模式的消息处理实现 3.1 观察者模式(Observer Pattern) 3.2 命令模式(Command Pattern) 四、实战场景…...
LiveCharts.WPF图表模块封装
WPF LiveCharts.WPF 封装实现 下面是一个完整的 WPF LiveCharts.WPF 封装实现,提供了常用图表的简单使用方式,并支持数据绑定和更新。 一、LiveCharts.WPF 封装类 1. 图表基类 (ChartBase.cs) using LiveCharts; using LiveCharts.Wpf; using System.Collections.Generic;…...
微信小程序,基于uni-app的轮播图制作,轮播图本地文件图片预览
完整代码 <template><swiper class"banner" indicator-dots circular :autoplay"false"><swiper-item v-for "item in picture" :key"item.id"><view><image tap"onPreviewImage(item.img)" :…...
【QQmusic】复习笔记第四章分点讲解
4.1 音乐加载 功能概述 该部分实现了从本地磁盘加载音乐文件到程序中,并在界面上显示的功能。通过QFileDialog类创建文件选择对话框,用户可选择多个音乐文件,程序筛选出有效音频文件后,交由MusicList类管理,并更新到…...
设置右键打开VSCode
在日常的开发工作中,VSCode 是一款非常受欢迎的代码编辑器。为了更加便捷地使用它,我们可以将 VSCode 添加到右键菜单中,这样只需右键点击文件或文件夹,就能快速用 VSCode 打开,极大地提高工作效率。下面我就来介绍一下…...
数据结构和算法(八)--2-3查找树
目录 一、平衡树 1、2-3查找树 1.1、定义 1.2、查找 1.3、插入 1.3.1、向2-结点中插入新键 1.3.2、向一棵只含有一个3-结点的树中插入新键 1.3.3、向一个父结点为2-结点的3-结点中插入新键 1.3.4、向一个父结点为3-结点的3-结点中插入新键 1.3.5、分解根结点 1.4、2…...
JSAPI2.4——正则表达式
一、语法 const str 一二三四五六七八九十 //判断内容 const reg /二/ //判断条件 console.log(reg.test(str)); //检查 二、test与exec方法的区别 test方法:用于判断是否符合规则的字符串,返回值是布尔值 exec方法&…...
FPGA 100G UDP纯逻辑协议栈
随着器件等级的升高,高速serdes的线速率也随之提高,RFSOC 4x最大可支持100G,主流方案为RDMA方案,该方案相对比较复杂,除了需要负责逻辑端的开发,还需操作系统中开发RDMA的驱动,对于对丢包不那么…...
分享一个可以批量巡检GET和POST接口的Shell脚本
一、场景痛点与需求分析 在分布式系统架构中,服务接口的可用性和稳定性直接影响业务连续性。当面临以下场景时,需批量巡检GET和POST接口: 上线验证:新版本发布后批量验证核心接口 故障恢复:异常数据修复后的批量重试…...
机器学习之一:机械式学习
正如人们有各种各样的学习方法一样,机器学习也有多种学习方法。若按学习时所用的方法进行分类,则机器学习可分为机械式学习、指导式学习、示例学习、类比学习、解释学习等。这是温斯顿在1977年提出的一种分类方法。 有关机器学习的基本概念,…...
区分PROJECT_SOURCE_DIR, CMAKE_SOURCE_DIR,CMAKE_CURRENT_SOURCE_DIR
目录 示例工程 PROJECT_SOURCE_DIR的行为 CMAKE_SOURCE_DIR的行为 CMAKE_CURRENT_SOURCE_DIR 示例工程 根目录 |-----CMakeLists.txt |-----sub1 |--------CMakeLists.txt |-----sub2 |--------CMakeLists.txt 根目录下的CMakeList.txt: project(main)message("main …...
Python循环结构深度解析与高效应用实践
引言:循环结构在编程中的核心地位 循环结构作为程序设计的三大基本结构之一,在Python中通过while和for-in两种循环机制实现迭代操作。本文将从底层原理到高级应用,全面剖析Python循环机制的使用技巧与优化策略,助您掌握高效迭代的…...
25【干货】在Arcgis中根据字段属性重新排序并自动编号的方法(二)
上一篇关于属性表自动编号的文章因为涉及到代码(【干货】在Arcgis中根据字段属性重新排序并自动编号的方法(一)),担心大家有些东西确实不熟悉,今天就更新一篇不需要代码也能达到这个目的的方法。主要的思路…...
SinSR模型剪枝实验报告
SinSR模型剪枝实验报告 实验概述 我成功地对SinSR模型进行了L1范式剪枝,剪枝比例为50%。通过分析剪枝前后的模型参数和性能,我们得出了以下结论。 剪枝实现方法 创建专用的main_prune.py脚本,用于剪枝训练。创建quick_prune.py脚本&#…...
IT社团分析预测项目(pandas、numpy、sklearn)
IT社团人数的增长陷入迟滞,同时不同目标任务和不同经营模式的社团更是层出不穷。在面临内忧外患的情况下,本社团希望结合社团行业现状,分析同学和出勤的数据,挖据数据中的信息,通过对人数流失进行预测寻找到相应的对策…...
C语言中位段的应用
一,位段的主要应用场景 硬件寄存器操作 嵌入式开发中,硬件寄存器通常以位为单位控制设备状态。位段可直接映射到寄存器,简化位操作: typedef struct {unsigned int enable : 1; // 使能位unsigned int mode : 3; // 模式选择&…...
【Linux网络#1】:网络基础知识
1、网络发展 在计算机发展历程中,经历过下面四个阶段: 1.独立模式 独立模式:计算机之间相互独立,每台计算机做自己的事情,彼此之间没有直接信息传递。如果两台计算机需要通信就需要将当前计算机的数据通过某种方式拷贝…...
基于物联网的园林防火监测系统
标题:基于物联网的园林防火监测系统 内容:1.摘要 随着全球气候变化和人类活动影响,园林火灾发生频率呈上升趋势,给生态环境和人类生命财产造成巨大损失。为有效预防和应对园林火灾,本文提出基于物联网的园林防火监测系统。该系统综合运用传感…...
华为云loT物联网介绍与使用
🌐 华为云 IoT 物联网平台详解:构建万物互联的智能底座 随着万物互联时代的到来,物联网(IoT)已成为推动数字化转型的关键技术之一。华为云 IoT 平台(IoT Device Access)作为华为云的核心服务之…...
Redis 数据类型全览:特性、场景与操作实例
Redis 是一款开源的内存数据库,支持多种数据类型,以下是对常见 Redis 数据类型的介绍: 1. String(字符串) 描述 字符串是 Redis 里最基础的数据类型,其值可以是简单的字符串、数字,甚至是二进…...
Qt动态库信号崩溃问题解决方案
在Qt中,当动态库向主程序发送信号导致崩溃时,通常涉及线程安全或对象生命周期问题。以下是逐步解决方案: 1. 检查线程上下文 问题:动态库所在的线程与主程序线程不同,跨线程信号未正确处理。解决方案: 显式…...
Go设计模式-观察者模式
简介 在软件开发中,我们常常会遇到这样的场景:一个对象的状态变化需要通知到多个其他对象,让它们做出相应的反应。观察者模式(Observer Pattern)就是解决这类问题的一种设计模式。在 Go 语言中,由于其简洁…...
《TCP/IP详解 卷1:协议》之第七、八章:Ping Traceroute
目录 一、ICMP回显请求和回显应答 1、ICMP回显请求 2、ICMP回显应答 二、ARP高速缓存 三、IP记录路由选项(Record Route,RR) 1、记录路由选项的工作过程 2、RR 选项的 IP 头部格式 2.1、RR 请求 2.2、RR响应 四、ping 的去返路径 五…...
Unity任务系统笔记
数据结构设计 任务基类包括的字段: string 任务内容; Transform 任务目的地; MyCharacter 任务开启后要更新对话的NPC; MyTalkData 任务开启后相关NPC要说的对话数据; 共同方法:开启任务、完成任务。…...
Three.js + React 实战系列-3D 个人主页:构建 Hero 场景组件(项目核心)✨
在本节中,我们将完成整个 3D 主业项目中最核心的组件 —— Hero.jsx。 这个组件作为首页的主视觉部分,整合了 3D 模型、动画相机、交互按钮与自适应布局,构建出一个立体、酷炫、可交互的主场景。 前置准备: ✅安装依赖ÿ…...
线程池(二):深入剖析synchronized关键字的底层原理
线程池(二):深入剖析synchronized关键字的底层原理 线程池(二):深入剖析synchronized关键字的底层原理一、基本使用1.1 修饰实例方法1.2 修饰静态方法1.3 修饰代码块 二、Monitor2.1 Monitor的概念2.2 Moni…...
网络原理 - 9
目录 数据链路层 以太网 以太网帧格式 MAC 地址 DNS(Domain Name System) 完! 数据链路层 这里的内容也是简单了解,除非是做交换机开发,一般程序员不需要涉及~~ 以太网 ”以太网“不是一种具体的网络…...
springboot入门-业务逻辑核心service层
在 Spring Boot 中,Service 层是业务逻辑的核心,负责协调数据访问层(Repository 或 Mapper)和控制器层(Controller),处理业务规则、事务管理以及数据转换。以下是 Service 层的详细说明、常用注…...
在RHEL 10上安装和配置TFTP服务器(不使用xinetd)
RHEL10已经废弃xinetd,使用下面的方式安装配置TFTP服务器。 1. 安装TFTP服务器和客户端 sudo dnf install tftp-server tftp -y 2. 配置TFTP服务器 创建TFTP根目录并设置权限 sudo mkdir -p /var/lib/tftpboot sudo chmod -R 777 /var/lib/tftpboot sudo chown -R…...
AIGC在游戏开发中的革命:自动化生成3A级游戏内容
一、智能游戏开发架构 1.1 传统开发痛点与AIGC创新 开发环节 传统痛点 AIGC解决方案 角色原画设计 美术资源产能瓶颈 文生图3D模型自动生成 场景搭建 重复劳动占比高 程序化生成风格迁移 NPC行为设计 模式化严重 强化学习驱动智能行为 任务系统 剧情线性缺乏变化 动态剧情生成系…...
ChatGPT、deepseek、豆包、Kimi、通义千问、腾讯元宝、文心一言、智谱清言代码能力对比
均使用测试时的最强模型 均是一次对话,对话内容一样 均开启深度思考 能联网的都联网了,但是作用不大,因为蓝桥杯刚考完,洛谷题目刚上传没多久 问题一测试了两遍 从问题三开始不再测试智谱清言(它思考时间太长了,前两个…...