数据库系统的结构

Jun 07, 2016 pm 05:43 PM
データベース システム 構造

我学数据库(7)--数据库系统的结构 在软件行业,软件是讲究结构的,数据库管理系统毕竟是一个软件,所以也讲结构。考察数据库系统的结构可以从多种不同的角度或不同的层次。 从系统本身来讲,数据库系统通常采用三级模式结构,也就是系统内部的结构。如果从数

我学数据库(7)--数据库系统的结构

  在软件行业,软件是讲究结构的,数据库管理系统毕竟是一个软件,所以也讲结构。考察数据库系统的结构可以从多种不同的角度或不同的层次。

  从系统本身来讲,数据库系统通常采用三级模式结构,也就是系统内部的结构。如果从数据库最终用户角度来看,其结构又分单用户结构、主从式结构、分布式结构、C/S结构、B/S结构以及浏览器/应用服务器/数据库服务器结构等,即数据系统外部体系结构。

  按照先后,逐个对三级模式以及各种外部体系结构进行详细了解。在学习三级模式之前,先了解一下数据库系统的模式的概念。

  数据模型中有“型”和“值”的概念。型是指对某一类数据的结构和属性的说明,值是型的一个具体赋值。在前面的随笔当中也有提及,比如实体型和实体,以及实体集的概念。模式是数据库中全体数据的逻辑结构和特征的描述,也就是型的描述。模式的一个具体值成为模式的一个实例。一个模式可以有多个实例,比如学生信息数据库,假设A和B学校使用同一模式的数据库,A学校的信息库和B学校信息库肯定是不同的,因为学生信息是不一样的。模式是相对稳定的,实例是变动的,因为数据是不断的在更新。模式是数据的结构和联系,而实例反映的是数据库某一时刻的状态。基于不同数据模型的数据库管理系统种类很多,在不同操作系统之上,数据的存储结构也不同,但在体系结构上通常具有相同的特征,即采用三级模式结构并提供两级映像功能。

  数据库的三级模式结构是指数据库系统由外模式、模式和内模式三级构成,下图是数据库系统的三级模式结构:

 

         外模式也称子模式或用户模式,它是应用程序员和最终用户能够看见和使用的局部数据的逻辑结构和特征的描述,是数据库用户的数据视图,由图中也可以看出,外模式是与某一应用有关的数据的逻辑表示,而且一个数据库可以有好多个子模式,当然也可以看出,同一外模式可以有多个应用模式与之对应。由此可以得出,为了满足其他的需求可以在同一外模式上再添加其它的应用。但就不同应用来说,即使是使用的同一数据,在结构、类型以及安全级别等都可以不同。从上图中也可以看出,香港服务器,应用当中的任何一个都没有使用两个或以上外模式的。还有一个很有用的信息就是一个应用只能从对应外模式中取得数据而不能从其它的外模式中取数据,这就为保证数据库的安全提供了一个很有利的保护措施。

         模式也称逻辑模式,是数据的逻辑结构和特征的描述,是所有用户的公共数据视图。它是数据库系统模式结构的中间层次,不与数据的物理细节和硬件环境有关,也不与具体的应用程序以及高级程序设计语言有关。一个数据库只有一个模式,它将以一种数据模型为基础,统一考虑所有用户的需求,并将两者有机结合成一个逻辑整体。定义模式的时候需要定义数据的逻辑结构,而且还要定义数据之间的联系以及与安全性和完整性有关的要求。

         内模式也称存储模式,一个数据库只有有一个内模式,用来描述物理结构和存储方式,是数据在内部的表示方式。比如用堆存储记录或者CLUSTER存储,索引是B+树索引还是hash索引。

  这三级模式是对数据的三级抽象,可以让用户逻辑地抽象处理数据而不必关心数据的具体表示方式和存储方式。为了能够实现这三个层次的联系和转换,数据库管理系统提供了两层映像:外模式/模式映像和模式/内模式映像。

  在前面的随笔中提到过数据库系统对比手工管理数据以及文件系统的有点,其中一条便是数据独立性高,而正是两层映像功能保证了较高的数据独立性,数据独立性又分逻辑独立性和物理独立性。

  外模式/模式映像,前面写到模式是数据的全局逻辑结构,而外模式是数据的局部逻辑结构,一个模式可以有多个外模式。当模式改变时,如增加新的关系、属性等,之后由数据库管理员对各个外模式/模式映像进行调整,而不必去调整外模式。应用程序是根据外模式编写,这样应用程序无需更改,这就保证了数据与程序的逻辑独立性,即数据的逻辑独立性。

  数据库只有一个模式,也只有一个内模式,所以也就只有一个模式/内模式映像,它定义了全局逻辑结构与存储结构之间的对应关系。单数据的存储结构改变以后,数据库管理员可对模式/内模式映像做相应改变,模式不用改变,所以呢应用程序也不用改变。这就保证了数据的物理独立性。

  数据库系统一般由数据库、数据库管理系统及其开发工具、应用系统和数据库管理员构成。由于数据库系统数据量很大,加之DBMS功能很强大,所以数据库系统的硬件资源选择要求较高,比如要求有足够大的内存和磁盘空间等。数据库系统软件的主要有DBMS、操作系统、高级语言及其编译系统、以DBMS为中心的应用开发工具级为特定应用环境开发的数据库应用系统等。人员主要有数据库管理员、系统分析员和数据库设计人员、应用程序员和用户。(数据库管理员DBA,之后我会转发两篇关于DBA就业的文章,这两篇文章是我无聊的时候看到的,觉得不错,在这篇随笔之后分享给大家。)

  之后再来对对各种数据库系统外部体系结构做简要的了解。

  单用户结构:整个数据库系统(应用程序、DBMS、数据)装在一台计算机上,为一个用户独占,不同机器之间不能共享数据。

  主从式结构:一个主机带多个终端的多用户结构,数据库系统存放在主机上,香港空间,所有处理任务都由主机来完成,各个用户通过主机的终端并发地存取数据库,共享数据资源。

  分布式结构:数据库中的数据在逻辑上是一个整体,但物理地分布在计算机网络的不同结点上,网络中的每个结点都可以独立处理本地数据库中的数据,执行局部应用同时也可以同时存取和处理多个异地数据库中的数据,执行全局应用。

  C/S结构:把DBMS功能和应用分开,网络中某个(些)结点上的计算机专门用于执行DBMS功能,称为数据库服务器,简称服务器;其他结点上的计算机安装DBMS的外围应用开发工具,用户的应用系统,称为客户机。一种是集中的服务器结构,一台数据库服务器,多台客户机;一种是分布的服务器结构在网络中有多台数据库服务器,分布的服务器结构是客户/服务器与分布式数据库的结合。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

ファーウェイのQiankun ADS3.0インテリジェント運転システムは8月に発売され、初めてXiangjie S9に搭載される ファーウェイのQiankun ADS3.0インテリジェント運転システムは8月に発売され、初めてXiangjie S9に搭載される Jul 30, 2024 pm 02:17 PM

7月29日、AITO Wenjieの40万台目の新車のロールオフ式典に、ファーウェイの常務取締役、ターミナルBG会長、スマートカーソリューションBU会長のYu Chengdong氏が出席し、スピーチを行い、Wenjieシリーズモデルの発売を発表した。 8月にHuawei Qiankun ADS 3.0バージョンが発売され、8月から9月にかけて順次アップグレードが行われる予定です。 8月6日に発売されるXiangjie S9には、ファーウェイのADS3.0インテリジェント運転システムが初搭載される。 LiDARの支援により、Huawei Qiankun ADS3.0バージョンはインテリジェント運転機能を大幅に向上させ、エンドツーエンドの統合機能を備え、GOD(一般障害物識別)/PDP(予測)の新しいエンドツーエンドアーキテクチャを採用します。意思決定と制御)、駐車スペースから駐車スペースまでのスマート運転のNCA機能の提供、CAS3.0のアップグレード

常に新しい! Huawei Mate60シリーズがHarmonyOS 4.2にアップグレード:AIクラウドの強化、Xiaoyi方言はとても使いやすい 常に新しい! Huawei Mate60シリーズがHarmonyOS 4.2にアップグレード:AIクラウドの強化、Xiaoyi方言はとても使いやすい Jun 02, 2024 pm 02:58 PM

4月11日、ファーウェイはHarmonyOS 4.2 100台のアップグレード計画を初めて正式に発表し、今回は携帯電話、タブレット、時計、ヘッドフォン、スマートスクリーンなどのデバイスを含む180台以上のデバイスがアップグレードに参加する予定だ。先月、HarmonyOS4.2 100台アップグレード計画の着実な進捗に伴い、Huawei Pocket2、Huawei MateX5シリーズ、nova12シリーズ、Huawei Puraシリーズなどの多くの人気モデルもアップグレードと適応を開始しました。 HarmonyOS によってもたらされる共通の、そして多くの場合新しい体験を楽しむことができる Huawei モデルのユーザーが増えることになります。ユーザーのフィードバックから判断すると、HarmonyOS4.2にアップグレードした後、Huawei Mate60シリーズモデルのエクスペリエンスがあらゆる面で向上しました。特にファーウェイM

Go 言語はデータベースの追加、削除、変更、クエリ操作をどのように実装しますか? Go 言語はデータベースの追加、削除、変更、クエリ操作をどのように実装しますか? Mar 27, 2024 pm 09:39 PM

Go 言語は、効率的かつ簡潔で習得が容易なプログラミング言語であり、同時プログラミングやネットワーク プログラミングに優れているため、開発者に好まれています。実際の開発ではデータベースの操作が欠かせませんが、今回はGo言語を使ってデータベースの追加・削除・変更・クエリ操作を実装する方法を紹介します。 Go 言語では、データベースを操作するために通常、よく使用される SQL パッケージや gorm などのサードパーティ ライブラリを使用します。ここでは SQL パッケージを例として、データベースの追加、削除、変更、クエリ操作を実装する方法を紹介します。 MySQL データベースを使用していると仮定します。

Hibernate はポリモーフィック マッピングをどのように実装しますか? Hibernate はポリモーフィック マッピングをどのように実装しますか? Apr 17, 2024 pm 12:09 PM

Hibernate ポリモーフィック マッピングは、継承されたクラスをデータベースにマップでき、次のマッピング タイプを提供します。 join-subclass: 親クラスのすべての列を含む、サブクラス用の別個のテーブルを作成します。 table-per-class: サブクラス固有の列のみを含む、サブクラス用の別個のテーブルを作成します。 Union-subclass: join-subclass と似ていますが、親クラス テーブルがすべてのサブクラス列を結合します。

iOS 18では、紛失または破損した写真を復元するための新しい「復元」アルバム機能が追加されます iOS 18では、紛失または破損した写真を復元するための新しい「復元」アルバム機能が追加されます Jul 18, 2024 am 05:48 AM

Apple の最新リリースの iOS18、iPadOS18、および macOS Sequoia システムでは、さまざまな理由で紛失または破損した写真やビデオをユーザーが簡単に回復できるように設計された重要な機能が写真アプリケーションに追加されました。この新機能では、写真アプリのツール セクションに「Recovered」というアルバムが導入され、ユーザーがデバイス上に写真ライブラリに含まれていない写真やビデオがある場合に自動的に表示されます。 「Recovered」アルバムの登場により、データベースの破損、カメラ アプリケーションが写真ライブラリに正しく保存されない、または写真ライブラリを管理するサードパーティ アプリケーションによって失われた写真やビデオに対する解決策が提供されます。ユーザーはいくつかの簡単な手順を実行するだけで済みます

HTML がデータベースを読み取る方法の詳細な分析 HTML がデータベースを読み取る方法の詳細な分析 Apr 09, 2024 pm 12:36 PM

HTML はデータベースを直接読み取ることはできませんが、JavaScript と AJAX を通じて実現できます。この手順には、データベース接続の確立、クエリの送信、応答の処理、ページの更新が含まれます。この記事では、JavaScript、AJAX、および PHP を使用して MySQL データベースからデータを読み取る実践的な例を示し、クエリ結果を HTML ページに動的に表示する方法を示します。この例では、XMLHttpRequest を使用してデータベース接続を確立し、クエリを送信して応答を処理することで、ページ要素にデータを埋め込み、データベースを読み取る HTML の機能を実現します。

ファーウェイは、心拍数に基づいてユーザーの感情状態を評価できるスマートウェアラブル分野でXuanjiセンシングシステムを発売する ファーウェイは、心拍数に基づいてユーザーの感情状態を評価できるスマートウェアラブル分野でXuanjiセンシングシステムを発売する Aug 29, 2024 pm 03:30 PM

最近、ファーウェイは、Xuanjiセンシングシステムを搭載した新しいスマートウェアラブル製品を9月に発売すると発表しました。これはファーウェイの最新スマートウォッチとなる予定です。この新製品は、高度な感情的健康モニタリング機能を統合し、正確性、包括性、スピード、柔軟性、オープン性、拡張性という 6 つの特徴を備えた包括的な健康評価をユーザーに提供します。このシステムはスーパーセンシングモジュールを使用し、マルチチャンネル光路アーキテクチャ技術を最適化することで、心拍数、血中酸素、呼吸数などの基本的な指標の監視精度を大幅に向上させます。さらに、Xuanji センシング システムは、心拍数データに基づく感情状態の研究も拡張しており、生理学的指標に限定されず、ユーザーの感情状態やストレス レベルを評価することもでき、60 以上のスポーツのモニタリングをサポートしています。健康指標、心臓血管、呼吸器、神経、内分泌、

PHP で MySQLi を使用してデータベース接続を確立するための詳細なチュートリアル PHP で MySQLi を使用してデータベース接続を確立するための詳細なチュートリアル Jun 04, 2024 pm 01:42 PM

MySQLi を使用して PHP でデータベース接続を確立する方法: MySQLi 拡張機能を含める (require_once) 接続関数を作成する (functionconnect_to_db) 接続関数を呼び出す ($conn=connect_to_db()) クエリを実行する ($result=$conn->query()) 閉じる接続 ( $conn->close())

See all articles