検索

数据库(Database)技术是程序开发人员必须掌握的技术之一,调查数据显示,目前70%以上的应用软件都需要使用到数据库系统,也就是说,大多数应用系统都需要把数据库进行分类、存储和检索。 本章将介绍SQL Server数据库的基本操作,例如建立数据库、表、对表实

  数据库(Database)技术是程序开发人员必须掌握的技术之一,调查数据显示,目前70%以上的应用软件都需要使用到数据库系统,也就是说,大多数应用系统都需要把数据库进行分类、存储和检索。

  本章将介绍SQL Server数据库的基本操作,例如建立数据库、表、对表实施约束以满足数据的规范性要求,本章的重点将集中在基本的增加、修改、删除和查询语句。

  有关数据库设计、数据库高级对象和复杂的查询,将在后续课程中涉及。

  本章内容主要包括与数据库相关的背景知识以及一些基本概念和术语,还包括SQL Server管理器(SQL Server Management Studio)的基本操作,以及在管理器中创建和配置数据库的方法等。

1.1 使用数据库的必要性

  统计表明,2006年全球制造、复制出的数字信息量共计1610亿GB,大约是有史以来出版的图书信息总量的300万倍。从2006-2010年,数字信息量将增长6倍多。中国的数字信息量为127.1亿GB,占全球信息量的7.9%,这些信息大多数都基于多媒体内容、用户创建内容、16亿网民创建和传阅的信息,到2010年,全球数字信息量预计为9880亿GB。

  大量的数据、信息在不断产生,伴随而来的是如何安全有效地存储、检索、管理它们。对数据的有效存储、高校访问、方便共享和安全控制等问题成为信息时代的一个非常重要的问题。

  使用数据库可以高校且条理分明地存储数据,它使人们能够更加迅速和方便地管理数据,主要体现在以下几个方面。

  (1)可以机构化存储大量的数据信息,方便用户进行有效的检索和访问。数据库可以对数据进行分类保存,并且能够提供快速的查询,例如我们去Google搜索我们想要的数据,实际上,Google也是基于数据库和数据分类技术来达到快速搜索的目的的。

  (2)可以有效地保持数据信息的一致性、完整性,降低数据冗余。保存在数据库中的数据,可以很好地保存数据有效,不被破坏,而且数据自身有避免重复数据的功能,以此来降低数据的冗余。

  (3)可以满足应用的共享和安全方面的要求。

  把数据库放在数据库中在很多情况下也是出于安全的考虑,例如,如果把所有员工的信息、工资数据都放在磁盘文件上,那么工资的保密性就无从谈起,如果把员工信息和工资信息放在数据库中,则可以只允许查询和修改员工信息,而工资信息只允许财务人员查看,从而可以保证数据的安全性。

  (4)数据库技术能够方便智能化地分析,产生新的有用信息。

  例如,超市中把物品销售信息保存在数据库中,每个月销售情况的排名情况实际上决定下个月进货数量,数据库查询的信息实际上产生了新的“信息”。

  数据挖掘、联机分析技术最近发展非常快,其核心意义在于从一堆数据中分析出有用的新信息。

1.2 DBMS(数据库管理系统)的发展史

  数据库系统从20世纪50年代萌芽,20世纪60年代中期产生,到21世纪初,已经有40多年的历史,其间发生的巨大变化和得到的巨大成就是其他技术所远不及的。短短40年间,已经从第一代的网状、层次数据库,第二代的关系数据库系统,发展到第三代以面向对象模型为主要特征的数据库系统。其中,数据库技术与网络通信技术、人工智能技术、面向对象程序设计技术、并行计算技术等相互渗透,互相结合,成为当前数据库技术发展的主要特征。

 

1.2.1 萌芽阶段---文件系统

  文件系统是数据库系统的初级阶段,它出现在20世纪50-60年代,可以提供简单的数据共享和管理,但无法提供完整统一的管理和数据共享能力。

  由于它的功能较为简单,均附属于操作系统,并不成为独立的软件,所以一般把它视为数据库系统的原形,而不是严格意义上的数据库系统。

  基于文件系统的数据库系统虽然功能简单,但因为文件系统通常都能提供目录结构简单的文件组织形式,又往往直接作为操作系统的基本用户界面提供给客户使用,所以在管理较少、较为简单的数据,或者仅仅只是用来备份存储,极少用来查询,或查询要求比较简单的情况下,能够满足一定的应用需求。

  例如:企业员工提交工作计划、工作日志,常常使用电子文档的方式提交,这些提交的电子文档常被要求保存为具有格式名称的Word文件或纯文本文件,这样做有时候会很方便。文件压缩工具(如 ZIP 工具)和文件打包工具(如 TAR 工具)都是这个阶段的产物,并一起发展升级,现在还被广泛应用。

1.2.2 初级阶段---第一代数据库

  自20世纪60年代起,第一代数据库系统相继问世,它们是层次模型与网状模型的数据库系统,为统一管理和共享数据提供了有力的支撑。在这个时期,由于数据库系统的蓬勃发展,形成了注明的“数据库时代”。当然,这两种类型的数据库系统也有一定的不足,最主要的是,它们均脱胎于文件系统,因此,受文件物理结构的影响较大,用户在使用数据库时,需要对数据的物理结构有详细的了解,这对使用数据库的人员带来了许多麻烦。同时,数据库中表示数据模式的机构方式过于繁琐,也影响了数据库应用中越来越多的对数据结构的复杂要求的实现。

  在这个阶段中,网状模型的数据库由于它的复杂性、专用性,没有被广泛使用,而在层次模型数据库中,IBM公司的IMS(Information Management System,信息管理系统)层次模型数据库系统得到了极大的发展,不仅一度成为最大的数据库管理系统,拥有巨大的客户群,而且直到现在,仍然得到升级和支持,并不断与新技术结合,在特定的领域内体现出强大的生命力。

1.2.3 中级阶段---第二代数据库

  20世纪70年代初,随着数学基础方面取得的巨大成就,第二代数据库---关系数据库开始萌芽。

  自1970年IBM研究员德加·考特发表论文,阐述了关系模型的概念后,IBM大力投入关系数据库的研究。关系模型的数据库底层实现起来比较容易,所以很快被采用,并进入了众多商业数据库的研发计划,Oracle就是当时应关系数据模型的出现,而成立的一家专做(关系)数据库的公司。20世纪80年代初,IBM公司的关系数据库系统DB2问世,而Oracle公司将Oracle移植到桌面计算机上,这时,作为第二代数据库系统的关系数据库开发逐步取代层次与网状模式的数据库,成为占主导地位的数据库,成为行业主流。到目前为止,关系型数据库系统仍居数据库应用的主要地位。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
MySQL Index Cardinalityはクエリパフォーマンスにどのように影響しますか?MySQL Index Cardinalityはクエリパフォーマンスにどのように影響しますか?Apr 14, 2025 am 12:18 AM

MySQLインデックスのカーディナリティは、クエリパフォーマンスに大きな影響を及ぼします。1。高いカーディナリティインデックスは、データ範囲をより効果的に狭め、クエリ効率を向上させることができます。 2。低カーディナリティインデックスは、完全なテーブルスキャンにつながり、クエリのパフォーマンスを削減する可能性があります。 3。ジョイントインデックスでは、クエリを最適化するために、高いカーディナリティシーケンスを前に配置する必要があります。

MySQL:新規ユーザー向けのリソースとチュートリアルMySQL:新規ユーザー向けのリソースとチュートリアルApr 14, 2025 am 12:16 AM

MySQL学習パスには、基本的な知識、コアの概念、使用例、最適化手法が含まれます。 1)テーブル、行、列、SQLクエリなどの基本概念を理解します。 2)MySQLの定義、作業原則、および利点を学びます。 3)インデックスやストアドプロシージャなどの基本的なCRUD操作と高度な使用法をマスターします。 4)インデックスの合理的な使用や最適化クエリなど、一般的なエラーのデバッグとパフォーマンス最適化の提案に精通しています。これらの手順を通じて、MySQLの使用と最適化を完全に把握できます。

実際のmysql:例とユースケース実際のmysql:例とユースケースApr 14, 2025 am 12:15 AM

MySQLの実際のアプリケーションには、基本的なデータベース設計と複雑なクエリの最適化が含まれます。 1)基本的な使用法:ユーザー情報の挿入、クエリ、更新、削除など、ユーザーデータの保存と管理に使用されます。 2)高度な使用法:eコマースプラットフォームの注文や在庫管理など、複雑なビジネスロジックを処理します。 3)パフォーマンスの最適化:インデックス、パーティションテーブル、クエリキャッシュを使用して合理的にパフォーマンスを向上させます。

MySQLのSQLコマンド:実用的な例MySQLのSQLコマンド:実用的な例Apr 14, 2025 am 12:09 AM

MySQLのSQLコマンドは、DDL、DML、DQL、DCLなどのカテゴリに分割でき、データベースとテーブルの作成、変更、削除、データの挿入、更新、削除、複雑なクエリ操作の実行に使用できます。 1.基本的な使用には、作成可能な作成テーブル、INSERTINTO INSERTデータ、クエリデータの選択が含まれます。 2。高度な使用法には、テーブル結合、サブQueries、およびデータ集約のためのグループに参加します。 3.構文エラー、データ型の不一致、許可の問題などの一般的なエラーは、構文チェック、データ型変換、許可管理を介してデバッグできます。 4.パフォーマンス最適化の提案には、インデックスの使用、フルテーブルスキャンの回避、参加操作の最適化、およびデータの一貫性を確保するためのトランザクションの使用が含まれます。

InnoDBは酸コンプライアンスをどのように処理しますか?InnoDBは酸コンプライアンスをどのように処理しますか?Apr 14, 2025 am 12:03 AM

INNODBは、ロックメカニズムとMVCCを通じて、非論的、一貫性、および分離を通じて原子性を達成し、レッドログを介した持続性を達成します。 1)原子性:Undologを使用して元のデータを記録して、トランザクションをロールバックできることを確認します。 2)一貫性:行レベルのロックとMVCCを介してデータの一貫性を確保します。 3)分離:複数の分離レベルをサポートし、デフォルトでrepeatable -readが使用されます。 4)持続性:Redologを使用して修正を記録し、データが長時間保存されるようにします。

MySQLの場所:データベースとプログラミングMySQLの場所:データベースとプログラミングApr 13, 2025 am 12:18 AM

データベースとプログラミングにおけるMySQLの位置は非常に重要です。これは、さまざまなアプリケーションシナリオで広く使用されているオープンソースのリレーショナルデータベース管理システムです。 1)MySQLは、効率的なデータストレージ、組織、および検索機能を提供し、Web、モバイル、およびエンタープライズレベルのシステムをサポートします。 2)クライアントサーバーアーキテクチャを使用し、複数のストレージエンジンとインデックスの最適化をサポートします。 3)基本的な使用には、テーブルの作成とデータの挿入が含まれ、高度な使用法にはマルチテーブル結合と複雑なクエリが含まれます。 4)SQL構文エラーやパフォーマンスの問題などのよくある質問は、説明コマンドとスロークエリログを介してデバッグできます。 5)パフォーマンス最適化方法には、インデックスの合理的な使用、最適化されたクエリ、およびキャッシュの使用が含まれます。ベストプラクティスには、トランザクションと準備された星の使用が含まれます

MySQL:中小企業から大企業までMySQL:中小企業から大企業までApr 13, 2025 am 12:17 AM

MySQLは、中小企業に適しています。 1)中小企業は、顧客情報の保存など、基本的なデータ管理にMySQLを使用できます。 2)大企業はMySQLを使用して、大規模なデータと複雑なビジネスロジックを処理して、クエリのパフォーマンスとトランザクション処理を最適化できます。

Phantomの読み取りとは何ですか?Innodbはどのようにそれらを防ぐ(次のキーロック)?Phantomの読み取りとは何ですか?Innodbはどのようにそれらを防ぐ(次のキーロック)?Apr 13, 2025 am 12:16 AM

INNODBは、次のキーロックメカニズムを通じてファントムの読み取りを効果的に防止します。 1)Next-KeyLockingは、Row LockとGap Lockを組み合わせてレコードとギャップをロックして、新しいレコードが挿入されないようにします。 2)実際のアプリケーションでは、クエリを最適化して分離レベルを調整することにより、ロック競争を削減し、並行性パフォーマンスを改善できます。

See all articles

ホット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ヘンタイを無料で生成します。

ホットツール

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境