为了账号安全,请及时绑定邮箱和手机立即绑定

数据库按数据的组织方式来分可以分为哪三种模型?

数据库按数据的组织方式来分可以分为哪三种模型?

阿波罗的战车 2019-02-16 07:07:16
数据库按数据的组织方式来分可以分为哪三种模型
查看完整描述

2 回答

?
浮云间

TA贡献1829条经验 获得超3个赞

数据模型按不同的应用层次分成三种类型,分别是概念数据模型、逻辑数据模型、物理数据模型

(1)概念数据模型(ConceptualDataModel):

简称概念模型,是面向数据库用户的实现世界的模型,主要用来描述世界的概念化结构,它使数据库的设计人员在设计的初始阶段,摆脱计算机系统及DBMS的具体技术问题.

集中精力分析数据以及数据之间的联系等,与具体的数据管理系统(Database Management System,DBMS)无关。概念数据模型必须换成逻辑数据模型,才能在DBMS中实现。 

(2)逻辑数据模型(Logical Data Model):

简称数据模型,这是用户从数据库所看到的模型,是具体的DBMS所支持的数据模型,如网状数据模型(Network Data Model)、层次数据模型(Hierarchical Data Model)等。此模型既要面向用户,又要面向系统,主要用于数据库管理系统(DBMS)的实现。 

(3)物理数据模型(Physical Data Model):

简称物理模型,是面向计算机物理表示的模型,描述了数据在储存介质上的组织结构,它不但与具体的DBMS有关,而且还与操作系统和硬件有关。每一种逻辑数据模型在实现时都有其对应的物理数据模型。

DBMS为了保证其独立性与可移植性,大部分物理数据模型的实现工作由系统自动完成,而设计者只设计索引、聚集等特殊结构。

扩展资料:

数据库模型

(1)对象模型

(2)层次模型(轻量级数据访问协议)

(3)网状模型(大型数据储存)

(4)关系模型

(5)面向对象模型

(6)半结构化模型

(7)平面模型(表格模型,一般在形式上是一个二维数组。如表格模型数据Excel)

数据库的架构可以大致区分为三个概括层次:内层、概念层和外层。

(1)内层:最接近实际存储体,亦即有关数据的实际存储方式。

(2)外层:最接近用户,即有关个别用户观看数据的方式。

(3)概念层:介于两者之间的间接层。



查看完整回答
反对 回复 2019-03-10
?
jeck猫

TA贡献1909条经验 获得超7个赞

1、层次模型:

①有且只有一个结点没有双亲结点(这个结点叫根结点)。

②除根结点外的其他结点有且只有一个双亲结点。

层次模型中的记录只能组织成树的集合而不能是任意图的集合。在层次模型中,记录的组织不再是一张杂乱无章的图,而是一棵"倒长"的树。

2、网状模型 :

①允许一个以上的结点没有双亲结点。

②一个结点可以有多个双亲结点。

网状模型中的数据用记录的集合来表示,数据间的联系用链接(可看作指针)来表示。数据库中的记录可被组织成任意图的集合。

3、关系模型: 

关系模型用表的集合来表示数据和数据间的联系。

每个表有多个列,每列有唯一的列名。

在关系模型中,无论是从客观事物中抽象出的实体,还是实体之间的联系,都用单一的结构类型

扩展资料

1、无条件查询

例:找出所有学生的的选课情况

SELECT st_no,su_no

FROM score

例:找出所有学生的情况

SELECT*

FROM student

“*”为通配符,表示查找FROM中所指出关系的所有属性的值。

2、条件查询

条件查询即带有WHERE子句的查询,所要查询的对象必须满足WHERE子句给出的条件。

例:找出任何一门课成绩在70以上的学生情况、课号及分数

SELECT UNIQUE student.st_class,student.st_no,student.st_name,student.st_sex,student.st_age,score.su_no,score.score

FROM student,score

WHERE score.score>=70 AND score.stno=student,st_no

这里使用UNIQUE是不从查询结果集中去掉重复行,如果使用DISTINCT则会去掉重复行。另外逻辑运算符的优先顺序为NOT→AND→OR。

例:找出课程号为c02的,考试成绩不及格的学生

SELECT st_no

FROM score

WHERE su_no=‘c02’AND score<60

3、排序查询

排序查询是指将查询结果按指定属性的升序(ASC)或降序(DESC)排列,由ORDER BY子句指明。

例:查找不及格的课程,并将结果按课程号从大到小排列

SELECT UNIQUE su_no

FROM score

WHERE score<60

ORDER BY su_no DESC

4、嵌套查询

嵌套查询是指WHERE子句中又包含SELECT子句,它用于较复杂的跨多个基本表查询的情况。

例:查找课程编号为c03且课程成绩在80分以上的学生的学号、姓名

SELECT st_no,st_name

FROM student

WHERE stno IN (SELECT st_no

FROM score

WHERE su_no=‘c03’ AND score>80 )

这里需要明确的是:当查询涉及多个基本表时用嵌套查询逐次求解层次分明,具有结构程序设计特点。在嵌套查询中,IN是常用到的谓词。若用户能确切知道内层查询返回的是单值,那么也可用算术比较运算符表示用户的要求。

5、计算查询

计算查询是指通过系统提供的特定函数(聚合函数)在语句中的直接使用而获得某些只有经过计算才能得到的结果。常用的函数有:

COUNT(*) 计算元组的个数

COUNT(列名) 对某一列中的值计算个数

SUM(列名) 求某一列值的总和(此列值是数值型)

AVG(列名) 求某一列值的平均值(此列值是数值型)

MAX(列名) 求某一列值中的最大值

MIN(列名) 求某一列值中的最小值

例:求男学生的总人数和平均年龄

SELECT COUNT(*),AVG(st_age)

FROM student

WHERE st_sex=‘男’

例:统计选修了课程的学生的人数

SELECT COUNT(DISTINCT st_no)

FROM score

注意:这里一定要加入DISTINCT,因为有的学生可能选修了多门课程,但统计时只能按1人统计,所以要使用DISTINCT进行过滤。



查看完整回答
反对 回复 2019-03-10
  • 2 回答
  • 0 关注
  • 2039 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信