数据库基础(1) . 关系型数据库

1.数据库 database

1.1.数据持久化

数据持久化(Data Persistence)指的是将程序中的数据保存到某种持久化的存储介质(如硬盘、SSD、磁带等)上的过程,使得即使在程序终止后,数据依然可以被保留下来并在下次启动时重新加载。

数据持久化是现代软件开发中的一个重要概念,特别是在构建需要长期存储数据的应用程序时,如数据库管理系统、配置管理系统、日志记录系统等。

1.1.1.持久化的重要性

  1. 数据保存:确保数据在系统关闭或崩溃后仍然存在。
  2. 数据恢复:在系统重启后可以从持久化存储中恢复数据。
  3. 数据共享:使得不同进程或机器之间可以共享数据。
  4. 数据备份:提供数据备份和恢复机制,防止数据丢失。

1.1.2.持久化技术

数据持久化可以通过多种方式进行,以下是一些常见的技术手段:

  1. 文件系统

    • 文本文件:简单的数据存储方式,适合小规模的数据记录,如配置文件。
    • 二进制文件:更紧凑的数据存储格式,适合大量数据的存储,但不如文本文件易读。
  2. 数据库

    • 关系型数据库(RDBMS):如MySQL、PostgreSQL,用于存储结构化数据。
    • 非关系型数据库(NoSQL):如MongoDB、Cassandra,适合存储非结构化或半结构化数据。
  3. 对象关系映射(ORM)

    • ORM框架(如Hibernate、Entity Framework)可以简化对象到关系数据库的映射,使得对象模型可以直接用于持久化操作。
  4. 内存数据库

    • 虽然主要存储在内存中,但通常会定期将数据刷盘(flush to disk),如Redis。
  5. 日志文件

    • 记录关键操作的日志,以便于审计和恢复。
  6. 配置管理系统

    • 如Git,不仅用于版本控制,也可以作为配置文件的持久化存储。
  7. 状态管理工具

    • 在客户端应用中,如Redux(JavaScript前端应用的状态管理)可以帮助管理应用的状态并持久化。

1.2.关系型数据库

Relational data model

曾经比较流行的数据模型有三种,即层次结构模型网状结构模型, 以及按关系理论建立的关系结构模型

关系模型是由Edgar F. Codd在20世纪70年代提出的,他因此获得了图灵奖。在关系模型中,数据被组织成一张或多张表格的形式,每张表格都有一个唯一的名称,称为关系。每张表由行(tuples)和列(attributes)组成,行代表一个特定的对象实例,而列定义了对象的属性或特征。

关键特性

  1. 表格化数据:数据以二维表格的形式存储,每一行代表一条记录,每一列代表一种属性。

  2. 数据独立性:逻辑结构与物理存储分离,应用程序不依赖于数据的物理存储位置。

  3. 数据完整性:提供了多种机制来保证数据的一致性和准确性,如主键约束、外键约束、唯一性约束等。

  4. 并发控制:允许多个用户或应用程序同时访问数据库而不发生冲突。

  5. 事务处理:支持ACID(原子性、一致性、隔离性、持久性)原则,确保数据的一致性和可靠性。

  6. 支持复杂的查询:SQL语言强大,支持复杂的查询操作。

1.3.数据库管理系统

(Database Management System) DBMS是一种操纵和管理数据库的大型软件,用于建立、使用和维护数据库。

1.3.1.MySQL

MySQL 是一个开源的关系型数据库管理系统,由MySQL AB公司开发,后来被Sun Microsystems收购,现在属于Oracle公司。MySQL以其高效、稳定和灵活性著称,特别适用于Web应用程序。

  • 特点
    • 开源:免费使用,社区版提供了丰富的功能。
    • 高性能:支持多种存储引擎,如InnoDB、MyISAM等,提供了良好的性能。
    • 跨平台:支持Windows、Linux、Unix等多种操作系统。
    • 易用性:安装和配置相对简单,支持图形化管理工具如phpMyAdmin。
    • 插件式架构:支持多种存储引擎和插件,可以根据需要选择不同的组件。

1.3.2.Oracle Database

Oracle Database 是由Oracle公司开发的企业级关系型数据库管理系统。它是全球最大的企业级数据库之一,以其高可用性、安全性和可扩展性而闻名。

  • 特点
    • 企业级功能:支持高级特性如分区、并行查询等。
    • 高可用性:提供多种高可用解决方案,如Real Application Clusters (RAC) 和Data Guard。
    • 安全性:具备先进的安全措施,支持细粒度的访问控制。
    • 集成性:与其他Oracle产品(如中间件、应用服务器)高度集成。
    • 多模型支持:除了关系型数据,还支持JSON、XML等非关系型数据存储。

1.3.3.Microsoft SQL Server

Microsoft SQL Server 是微软推出的关系型数据库管理系统,主要用于Windows操作系统平台,也支持Linux。

  • 特点
    • 集成开发环境:与Visual Studio和.NET Framework紧密集成。
    • 分析能力:支持OLAP(在线分析处理)和数据仓库功能。
    • 商务智能:提供报表服务、分析服务等功能,方便进行数据分析。
    • 云支持:支持Azure SQL Database,可以部署在云端。
    • 多平台支持:除了Windows,SQL Server 2017及以后版本也支持Linux和Docker容器。

1.3.4.IBM DB2

IBM DB2 是IBM推出的一种高性能的关系型数据库管理系统,广泛应用于大型企业和金融行业。

  • 特点
    • 高性能:优化的查询处理引擎,适用于大规模数据处理。
    • 自动管理:自动索引、自动调优等功能减少管理负担。
    • 多平台支持:支持多种操作系统,包括Windows、Linux、Unix、z/OS等。
    • 多模型支持:除了关系型数据库,DB2还支持NoSQL、JSON、XML等数据类型。
    • 云兼容:支持IBM Cloud和其他公共云平台。

1.3.5.PostgreSQL

PostgreSQL 是一个强大的开源关系型数据库系统,以其稳定性、功能丰富和遵守SQL标准而受到开发者青睐。

  • 特点
    • 标准支持:严格遵循SQL标准,支持SQL:2008标准。
    • 扩展性强:支持多种存储引擎,可以通过插件扩展功能。
    • 多模型支持:除了关系型数据,还支持JSON、XML等非关系型数据存储。
    • 事务处理:支持ACID特性,确保数据一致性。
    • 跨平台:支持多种操作系统,包括Windows、Linux、Unix等。

在这里插入图片描述

1.4.非关系型数据库 NoSQL

NoSQL(Not Only SQL)数据库是一种不同于传统关系型数据库的设计理念和技术体系。

NoSQL数据库主要针对大规模数据分布式存储的需求而设计,尤其适合处理大规模的数据集,并且在分布式环境中提供高性能和高可扩展性。

1.4.1.NoSQL 的特点

  1. 非关系型:与关系型数据库相比,NoSQL数据库通常不强制使用固定的表格模式。
  2. 分布式架构:支持横向扩展,可以在多个服务器上分布存储数据。
  3. 高可用性:通过复制和分区来提高数据的可用性和可靠性。
  4. 灵活性:数据模型可以是文档、键值对、列族或图等。
  5. 高性能:针对特定类型的数据操作进行了优化,通常在读写性能方面优于关系型数据库。

1.4.2.NoSQL 数据库的分类

NoSQL数据库根据其存储数据的方式可以大致分为以下几种类型:

  1. 键值存储(Key-Value Stores)

    • 特点:数据以键值对的形式存储,每个键对应一个值。
    • 用途:适合会话管理、购物车存储等场景。
    • 示例:Redis、Voldemort。
  2. 文档数据库(Document-Oriented Databases)

    • 特点:数据以文档形式存储,常用格式为JSON或BSON。
    • 用途:适合存储和查询复杂结构的数据,如博客文章、用户档案等。
    • 示例:MongoDB、CouchDB。
  3. 列族存储(Column-Family Stores)

    • 特点:数据按列族存储,适合分析型应用。
    • 用途:适合数据挖掘、实时分析等场景。
    • 示例:Apache Cassandra、HBase。
  4. 图数据库(Graph Databases)

    • 特点:数据以图的形式存储,节点和边表示实体及其关系。
    • 用途:适合社交网络分析、推荐系统等。
    • 示例:Neo4j、JanusGraph。
  5. 内存数据库(In-Memory Databases)

    • 特点:数据主要存储在内存中,提供极高的读写性能。
    • 用途:适合需要极高读写速度的应用场景。
    • 示例:Redis(尽管Redis通常是键值存储,但它也有内存数据库的特点)。

1.4.3.常见NoSQL

高并发读写 (key-value) Redis,Tokyo Cabinet,Flare

海量数据的高效存储和访问(面向文档)MongeDB,CouchDB

高可扩展性和高可用性 Cassandra , Voldemort

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

Python学习的自我理解和想法(27)

学的是b站的课程(千锋教育),跟老师写程序,不是自创的代码! 今天是学Python的第27天,学的内容是python操作pptx和pdf,但是这节博客只会介绍如何新建pptx和加密pdf。开学了,时间不多&…

鸿蒙移动应用开发-------初始arkts

一. 什么是arkts ArkTS是HarmonyOS优选的主力应用开发语言。 ArkTS围绕应用开发在TypeScript(简称TS)生态基础上做了进一步扩展,保持了TS的基本风格,同时通过规范定义强化开发期静态检查和分析,提升程序执行稳定性和…

Linux(CentOS)安装 JDK

1、下载 JDK 官网:https://www.oracle.com/ 2、上传 JDK 文件到 CentOS,使用FinalShell远程登录工具,并且使用 root 用户登录 3、解压 JDK 创建目录 /export/server mkdir -p /export/server 解压到目录 /export/server tar -zxvf jdk-17…

qt QStandardItemModel详解

1、概述 QStandardItemModel是Qt框架中提供的一个基于项的模型类,用于存储和管理数据,这些数据可以以表格的形式展示在视图控件(如QTableView、QTreeView等)中。QStandardItemModel支持丰富的数据操作,包括添加、删除…

SpringBoot框架在在线教育领域的应用

4系统概要设计 4.1概述 本系统采用B/S结构(Browser/Server,浏览器/服务器结构)和基于Web服务两种模式,是一个适用于Internet环境下的模型结构。只要用户能连上Internet,便可以在任何时间、任何地点使用。系统工作原理图如图4-1所示: 图4-1系统工作原理…

【论文分享】基于多源大数据的高密度城市健康资源可达性与公平性评价

评估城市健康设施的可达性和公平性对于有效配置城市健康资源至关重要。本次我们给大家带来一篇SCI论文的全文翻译。该论文从新的视角定义和分类城市中的健康相关设施,考虑居民的主动和被动健康寻求行为,构建一个综合性框架来评估健康设施的邻近性、互补性…

Vue学习之路17----事件

可以自定义事件让子组件向父组件传值 1.使用emit 2.使用props 3.使用mitt 其实mitt和第一种方法类似,都用emitt事件,但是mitt不局限于父子之间通信,他可以在任意2个组件之间通信, 虽然需要安装,但mitt很小&#xff…

基于梯度的快速准确头部运动补偿方法在锥束CT中的应用|文献速递-基于深度学习的病灶分割与数据超分辨率

Title 题目 A gradient-based approach to fast and accurate head motion compensation in cone-beam CT 基于梯度的快速准确头部运动补偿方法在锥束CT中的应用 01 文献速递介绍 锥束计算机断层扫描(CBCT)系统在灵活性方面比螺旋多排探测器计算机断…

基于 JavaWeb 的宠物商城系统(附源码,文档)

博主介绍:✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取源码联系🍅 👇🏻 精彩专栏推荐订阅👇…

Redis学习:BitMap/HyperLogLog/GEO案例 、布隆过滤器BloomFilter、缓存预热+缓存雪崩+缓存击穿+缓存穿透

Redis学习 文章目录 Redis学习1、BitMap/HyperLogLog/GEO案例2. 布隆过滤器BloomFilter3. 缓存预热缓存雪崩缓存击穿缓存穿透 1、BitMap/HyperLogLog/GEO案例 真实需求面试题 亿级数据的收集清洗统计展现对集合中数据进行统计,基数统计,二值统计&#xf…

【论文速读】| PathSeeker:使用基于强化学习的越狱攻击方法探索大语言模型的安全漏洞

基本信息 原文标题: PathSeeker: Exploring LLM Security Vulnerabilities with a Reinforcement Learning-Based Jailbreak Approach 原文作者: Zhihao Lin, Wei Ma, Mingyi Zhou, Yanjie Zhao, Haoyu Wang, Yang Liu, Jun Wang, Li Li 作者单位: Beihang University, Nany…

P2672 [NOIP2015 普及组] 推销员

P2672 [NOIP2015 普及组] 推销员 难度: 提高/省选- 。 考点:贪心、前缀和。 题意: ​ n n n 个住户,小明每走一米消耗 1 1 1 疲劳,第 i i i 个住户距离起点 S i S_i Si​ 米,同时走进住户沟通会累积…

软件工程技术专业在物联网应用开发中的关键技术与挑战

引言 物联网技术的蓬勃发展与广泛普及,极大地丰富了人们的日常生活,催生了诸如智能家居、智能交通、智能健康等一系列创新应用,为用户提供了更加智能化、个性化的服务体验。然而,物联网应用开发也随之迎来了诸多挑战,…

基于Multisim光控夜灯LED电路带计时功能(含仿真和报告)

【全套资料.zip】光控夜灯LED电路设计Multisim仿真设计数字电子技术 文章目录 功能一、Multisim仿真源文件二、原理文档报告资料下载【Multisim仿真报告讲解视频.zip】 功能 光控夜灯LED电路 1.采用纯数字电路,非单片机。 2.通过检测周围光线,光线暗自…

vue 3:监听器

目录 1. 基本概念 2. 侦听数据源类型 1. 监听getter函数 2. 监听 ref 或 reactive 的引用 3. 多个来源组成的数组 4. 避免直接传递值!!! 3. 深层侦听器 4. 立即回调的侦听器 5. 一次性侦听器 6. watchEffect() 7. 暂停、恢复和停止…

c 语言链表的简单使用

一、链表介绍 在 C 语言中,链表是一种常用的数据结构,用于动态地存储数据。链表中的每个元素称为节点,每个节点包含数据部分和指向下一个节点的指针。 1.1 链表的基本概念 定义:链表是一种物理存储单元上非连续、非顺序的存储结…

计算机网络——路由器构成

算路由表是分布式去算——你算你的,我算我的 输出队列非先来先传 调度发生在哪里 缓存队列一般是应对——来数据方向的速度过快问题

微信小程序uniapp基于Android的流浪动物管理系统 70c3u

文章目录 项目介绍具体实现截图技术介绍mvc设计模式小程序框架以及目录结构介绍错误处理和异常处理java类核心代码部分展示详细视频演示源码获取 项目介绍 以往流浪猫狗的救助网站相关信息的管理,都是工作人员手工统计。这种方式不但时效性低,而且需要查…

【Pikachu靶场:XSS系列】xss之过滤,xss之htmlspecialchars,xss之herf输出,xss之js输出通关啦

一、xss之过滤 <svg onloadalert("过关啦")> 二、xss之htmlspecialchars javascript:alert(123) 原理&#xff1a;输入测试文本为herf的属性值和内容值&#xff0c;所以转换思路直接变为js代码OK了 三、xss之href输出 JavaScript:alert(假客套) 原理&#x…

【$15000】 通过监控调试模式实现RCE

你有没有遇到过一个你直觉上知道存在漏洞的端点&#xff0c;但你却无法完全理解后端发生了什么或如何利用它&#xff1f;在这篇文章中&#xff0c;我将引导你了解一种技术&#xff0c;它将我的黑盒测试转变为半白盒测试。这种方法导致了多个漏洞的发现&#xff0c;并最终实现了…