5分钟认识数据库

在这里插入图片描述

什么是数据库?

  • 数据库是由一批数据构成的有序集合,这些数据被存放在结构化的数据表里。数据表之间相互关联, 反映了客观事物间的本质联系。数据库系统提供对数据的安全控制和完整性控制。
  • 数据库的概念诞生于 60 年前,随着信息技术和市场的快速发展 数据库技术层出不穷,随着应用的拓展和深入,数据库的数量和规模越来越大,其诞生和发展给计算机信息管理带来一场巨大的革命。
  • 数据库的发展大致划分为人工管理阶段、文件系统阶段 数据库系统阶段和高级数据库阶段。其种类大概有3种,即层次式数据库、网络式数据库和关系式数据库。不同种类的数据库按不同的数据结构来联系和组织。
  • 对于数据库的概念,没有一个完全固定的定义,随着数据库历史的发展,定义的内容也有很大的差异, 其中一种比较普遍的观点认为数据库(Database, DB 是个长期存储在计算机内的、有组织的、有共享的、统一管理的数据集合。它是一个按数据结构来存储和管理数据的计算机软件系统,即数据库包含两层含义一一千呆管数据的“仓库”以及数据管理的方法和技术。
  • 数据库的特点包括实现数据共享,减少数据冗余;采用特定的数据类型 具有较高的数据独立性有统一的数据控制功能。

数据表

在关系型数据库中,数据库表是一系列二维数组的集合,用来存储数据和操作数据的逻辑结构。它由纵向的列和横向的行组成,行被称为记录,是组织数据的单位;列被称为字段,每一列表示记录的一个属性,都有相应的描述信息,例如数据类型、数据宽度等。

数据类型

数据类型决定了数据在计算机中的存储格式,代表不同的信息类型 常用的数据类型有整数数据类型、浮点数数据类型、精确小数类型、二进制数据类型、日期/时间数据类型、字符串数据类型。表中的每一个字段就是某种指定数据类型,例如 employee表中的”工号“字段为整数数据,"年龄"字段为字符型数据。

主键

主键( PRIMARY KEY )又称主码,用于唯一地标识表中的每一条记录。用户可以定义表中的一列或多列为主键,注意主键列上不能有两行相同的值,也不能为空值。假如定义employee表,该表给每一个学生分配一个"工号",该编号作为数据表的主键,如果出现相同的值,将提示错误,系统不能确定查询的究竟是哪一条记录;如果把员工的“姓名”作为主键,则不能出现重复的名字,这与现实不相符,因此“姓名”字段不适合作为主键。

数据库系统

数据库系统有以下3个主要组成部分。

  • 数据库 用于存储数据的地方。
  • 数据库管理系统 用于管理数据库的软件。
  • 数据库应用程序 为了提高数据库系统的处理能力所使用的管理数据库的软件补充。

数据库( Database System) 提供了一个存储空间用于存储各种数据,可以将数据库视为一个存储数据的容器 一个数据库中可能包含许多文件,一个数据库系统中通常包含许多数据库。

数据库管理系统(Database Management System, DBMS )是用户创建、管理和维护数据库时所使用的软件,位于用户与操作系统之间,对数据库进行统一管理。DBMS 能定义数据存储结构,提供数据的操作机制,维护数据库的安全性、完整性和可靠性。

数据库应用程序( Database Application )虽然已经有了DBMS ,但是在很多情况下 DBMS 无法满足对数据管理的要求。数据库应用程序的使用可以满足对数据管理的更高要求,还可以使数据管理过程更加直观和友好。数据库应用程序负责与 DBMS 进行通信,访问和管理 DBMS 申存储的数据,允许用户插入、修改、删除数据库中的数据。
数据库系统如图所示:
在这里插入图片描述

SQL 语言

SQL 语言包含以下4个部分。
(1)数据定义语言(DDL): DROP、CREATE、ALTER等语句
(2)数据操作语言(DML): INSERT、UPDATE、DELETE语句
(3)数据查询语言(DQL):SELECT语句
(4)数据控制语言(DCL):GRANT、REVOKE、COMMIT、ROLLBACK等语句

数据库访问技术

  • ODBC(Open Database Connectivity ,开放数据库互连)技术为访问不同的 SQL 数据库提供了一个共同的接口。 ODBC 使用 SQL 作为访问数据的标准,这一接口提供了最大限度的互操作性 一个应用程序可以通过共同的一组代码访问不同的 SQL 数据库管理系统(DBMS)一个基于ODBC的应用程序对数据库的操作不依赖任何DBMS,不直接与 DBMS 打交道,所有的数据库操作由对应的 DBMS的ODBC驱动程序完成。也就是说,不论是 Access MySQL还是Oracle数据库,均可用ODBCAPI进行访问。由此可见 ODBC 的最大优点是能以统一的方式处理所有的数据库;
  • JDBC (Java Database Connectivity, Java 数据库连接〉是用于 Java 应用程序连接数据库的标准方法,是一种用于执行 SQL 语旬的 JavaAPI ,可以为多种关系型数据库提供统 访问,它由一组用 Java 语言编写的类和接口组成;
  • ADO.NET 是微软公司在.NET 框架下开发设计的一组用于和数据源进行交互的面向对象类库。ADO.NET 提供了对关系数据、 XML 和应用程序数据的访问,允许和不同类型的数据源以及数据库进行交互;
  • PDO(PHP Data Object )为 PHP 访问数据库定义了一个轻量级的、一致性的接口,它提供了一个数据访问抽象层,这样无论使用什么数据库都可以通过 致的函数执行查询和获取数据。

关系型数据模型

建立数据库系统离不开数据模型 模型是对现实世界的抽象 在数据库技术中用模型的概念描述数据库的结构与语义,对现实世界进行抽象,能表示实体类型及实体间联系的模型称为“数据模型"。

关系模型是由若干个关系模式组成的集合,关系模式的实例称为关系,每个关系实际上是一张二维表格。关系模型用键导航数据,其表格简单,用户只需用简单的查询语句就可以对数据库进行操作,并不涉及存储结构、访问技术等细节。SQL语言是关系数据库的代表性语言,已经得到了广泛的应用。典型的关系数据库产品有 DB2, Oracle Sybase、SQL Server等。关系数据库是以关系模型为基础的数库,是根据表、无组、字段之间的关系进行组织和访问数据的一种数据库,它通过若干个表来存取数据,并且通过关系将这些表联系在一起 关系数据库是目前应用最广泛的数据库。

关系模型有3个组成部分,即数据结构、数据操作和完整性规则。
关系模型建立在严格的数学概念的基础之上,它用二维表来描述实体实体间的联系。

例如在一个有关学生信息的名为 tudent 的表中,每个列包含所有作者的某个特定类型的信息,比如姓名,而每行包含了某个特定作者的所有信息,比如学号、姓名、性别、专业,如图所示。
在这里插入图片描述
关系模型的基本术语如下。

  • 关系(Relation ):一个二维表就是个关系。
  • 元组(Tuple ):二维表中的一行即为一个元组。
  • 属性(Attribute):二维表中的一列即为一个属性,给每个属性取一个名称即属性名。
  • 域(Domain) 属性的取值范围。

关系模式是对关系的描述,可表示为关系名(属性 ,属性,…, 属性 )。例如上面的关系可以描述为学生(学号,姓名,性别,专业)。

一个关系模型是若干个关系模式的集合。在关系模型中,实体以及实体间的联系都用关系来表示。例如学生、课程 、学生与课程之间的多对多联系在关系模型中可以如下表示:
学生(学号,姓名,性别,专业)
课程(课程号,课程名,学分)
选修(学号 课程号 成绩)

由于关系模型概念简单、清晰、易懂、易用,并有严密的数学基础以及在此基础上发展起来的关系数据理论,简化了程序开发及数据库建立的工作量,因而迅速获得了广泛的应用,并在数据库系统中占据了
统治地位。

关系型数据模型的操作与完整性

关系模型提供了 一组完备的高级关系运算,以支持对数据库的各种操作。关系数据库的数据操作语言
(DML)的语旬分为查询语旬和更新语旬两大类 查询语句用于描述用户的各类检索要求 :更新语旬用于
描述用户的插入、修改和删除等操作。关系数据操作语言建立在关系代数的基础之上,具有以下特点。

  1. 以关系为单位进行数据操作,操作的结果也是关系
  2. 非过程性强 很多操作只需指出做什么 ,而无须步步引导怎么去做。
  3. 以关系代数为基础,借助于传统的集合运算和专门的关系运 ,使关系数据语言具有很强的数据操作能力。

关系型数据模型的存储结构

关系型数据模型是以关系数学理论为基础的,用二维表结构来表示实体以及实体之间联系的模型称为关系模型。

在关系模型中把数据看成是二维表中的元素,操作的对象和结果都是二维表 一张二维表就是一个关系 。
关系模型与层次模型、网状模型的本质区别在于数据描述的一致性,模型概念单一。
在关系型数据库中每一个关系都是一个二维表,无论是实体本身还是实体间的联系均用称为“关系”的二维表来表示,它由表名、行和列组成。
表的每一行代表一个元组,每一列称为一个属性,这使得描述实体的数据本身能够自然地反映它们之间的联系。
传统的层次和网状模型数据库是使用链接指针来存储和体现联系的。尽管关系型数据库管理系统比层次型和网状型数据库管理系统的出现晚了很多年,但关系型数据库以其完备的理论基础、简单的模型、说明性的查询语言和使用方便等优点得到了最广泛的应用。

常见的关系型数据库管理系统

常见的关系型数据库管理系统产品有 Oracle、SQL Server、 Sybase DB2, Access 等。

参考书籍:《 MYSQL从入门到顶目实践(超值版》

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值