第一章 SQL Server数据库基础
数据库(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移植到桌面计算机上,这时,作为第二代数据库系统的关系数据库开发逐步取代层次与网状模式的数据库,成为占主导地位的数据库,成为行业主流。到目前为止,关系型数据库系统仍居数据库应用的主要地位。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

Go語言是一種高效、簡潔且易於學習的程式語言,因其在並發程式設計和網路程式設計方面的優勢而備受開發者青睞。在實際開發中,資料庫操作是不可或缺的一部分,本文將介紹如何使用Go語言實作資料庫的增刪改查操作。在Go語言中,我們通常會使用第三方函式庫來操作資料庫,例如常用的sql套件、gorm等。這裡以sql包為例介紹如何實作資料庫的增刪改查操作。假設我們使用的是MySQL資料庫。

Hibernate多態映射可映射繼承類別到資料庫,提供以下映射類型:joined-subclass:為子類別建立單獨表,包含父類別所有欄位。 table-per-class:為子類別建立單獨資料表,僅包含子類別特有列。 union-subclass:類似joined-subclass,但父類別表聯合所有子類別列。

蘋果公司最新發布的iOS18、iPadOS18以及macOSSequoia系統為Photos應用程式增添了一項重要功能,旨在幫助用戶輕鬆恢復因各種原因遺失或損壞的照片和影片。這項新功能在Photos應用的"工具"部分引入了一個名為"已恢復"的相冊,當用戶設備中存在未納入其照片庫的圖片或影片時,該相冊將自動顯示。 "已恢復"相簿的出現為因資料庫損壞、相機應用未正確保存至照片庫或第三方應用管理照片庫時照片和視頻丟失提供了解決方案。使用者只需簡單幾步

如何在PHP中使用MySQLi建立資料庫連線:包含MySQLi擴充(require_once)建立連線函數(functionconnect_to_db)呼叫連線函數($conn=connect_to_db())執行查詢($result=$conn->query())關閉連線( $conn->close())

HTML無法直接讀取資料庫,但可以透過JavaScript和AJAX實作。其步驟包括建立資料庫連線、發送查詢、處理回應和更新頁面。本文提供了利用JavaScript、AJAX和PHP來從MySQL資料庫讀取資料的實戰範例,展示如何在HTML頁面中動態顯示查詢結果。此範例使用XMLHttpRequest建立資料庫連接,發送查詢並處理回應,從而將資料填入頁面元素中,實現了HTML讀取資料庫的功能。

PHP處理資料庫連線報錯,可以使用下列步驟:使用mysqli_connect_errno()取得錯誤代碼。使用mysqli_connect_error()取得錯誤訊息。透過擷取並記錄這些錯誤訊息,可以輕鬆識別並解決資料庫連接問題,確保應用程式的順暢運作。

PHP是一種廣泛應用於網站開發的後端程式語言,它具有強大的資料庫操作功能,常用於與MySQL等資料庫進行互動。然而,由於中文字元編碼的複雜性,在處理資料庫中文亂碼時常常會出現問題。本文將介紹PHP處理資料庫中文亂碼的技巧與實踐,包括常見的亂碼原因、解決方法和具體的程式碼範例。常見的亂碼原因資料庫字元集設定不正確:資料庫建立時需選擇正確的字元集,如utf8或u

透過Go標準庫database/sql包,可以連接到MySQL、PostgreSQL或SQLite等遠端資料庫:建立包含資料庫連接資訊的連接字串。使用sql.Open()函數開啟資料庫連線。執行SQL查詢和插入操作等資料庫操作。使用defer關閉資料庫連線以釋放資源。
