热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

关系数据库(概念、关系操作、完整性、关系代数)

一、概念类东西关系模型三要素:关系数据结构、关系操作集合和关系完整性约束。用户角度:关系模型中数据的逻辑结构是一张扁平的二维表。(l )关系:一个
一、概念类东西

关系模型三要素:关系数据结构、关系操作集合和关系完整性约束。

用户角度:关系模型中数据的逻辑结构是一张扁平的二维表。

( l )关系:一个关系对应通常说的一张二维表;

( 2 )属性:表中的一列即为一个属性;

( 3 )域:属性的取值范围;(性别——男、女)

( 4 )笛卡尔积:所有域的所有取值的一个组合,不能重复。

( 5 )元组:表中的一行即为一个元组;

( 6 )主码:表中的某个属性组,它可以惟一确定一个元组;

( 7 )外码:F为关系R的一组属性(非主码),F是关系S中的主码,责称F为关系R的外码。

( 8 )分量:元组中的一个属性值;

( 9 )关系模式:对关系的描述,一般表示为关系名(属性 1 ,属性 2 , … ,属性 n )

 

关系的三种类型:基本表(真是存储的表)、查询表、视图(虚表)。

关系模式是型(静态)、关系是值(动态)。

关系数据库的型-----关系数据库模式        关系数据库的值----关系数据库

R(U,D,DOM,F)

R---关系名       U---属性集合     D---U中属性所来自的域     DOM---属性向域的映像集合    F---属性间数据的依赖关系

二、关系操作

分为查询操作和插入、删除、修改操作。

特点:操作对象和结果都是集合。

5种基本操作:选择、投影、并、差、笛卡尔积。(后面还有)

三、关系的完整性

三种完整性约束:实体完整性、参照完整性、用户定义完整性。(前两者必须满足)

1.实体完整性约束-----主属性不能为空

2.参照完整性约束-----外码(1)空值(2)等于对应关系中的主属性值

四、关系代数

关系代数运算符:

R∪S :由属于R或属于S的元组组成

R - S :由属于R而不属于S的所有元组组成

R∩S :由既属于R又属于S的元组组成

R × S:

   选择:σSdept = 'IS' (Student)

   投影:πSname,Sdept(Student)        投影针对的是列及属性,并在投影出来时删去重复值。

   除:设R与S的除运算结果为关系T,则T包含所有在R但不在S中的属性及其值,且T与S的元组的所有组合都在R。

   连接---在笛卡尔积的基础上做选择。(可进行两属性的比较进行连接)

   等值连接:从关系R与S的广义笛卡尔积中选取A、B属性值相等的那些元组

   自然连接:去除等值中重复列。

外连接:左外连接(LEFT OUTER JOIN或LEFT JOIN) 只保留左边关系R中的悬浮元组。

              右外连接(RIGHT OUTER JOIN或RIGHT JOIN) 只保留右边关系S中的悬浮元组。

 

 

 

 


推荐阅读
  • 本文介绍了2015年九月八日的js学习总结及相关知识点,包括参考书《javaScript Dom编程的艺术》、js简史、Dom、DHTML、解释型程序设计和编译型程序设计等内容。同时还提到了最佳实践是将标签放到HTML文档的最后,并且对语句和注释的使用进行了说明。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • PHP设置MySQL字符集的方法及使用mysqli_set_charset函数
    本文介绍了PHP设置MySQL字符集的方法,详细介绍了使用mysqli_set_charset函数来规定与数据库服务器进行数据传送时要使用的字符集。通过示例代码演示了如何设置默认客户端字符集。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文介绍了前端人员必须知道的三个问题,即前端都做哪些事、前端都需要哪些技术,以及前端的发展阶段。初级阶段包括HTML、CSS、JavaScript和jQuery的基础知识。进阶阶段涵盖了面向对象编程、响应式设计、Ajax、HTML5等新兴技术。高级阶段包括架构基础、模块化开发、预编译和前沿规范等内容。此外,还介绍了一些后端服务,如Node.js。 ... [详细]
  • 如何提高PHP编程技能及推荐高级教程
    本文介绍了如何提高PHP编程技能的方法,推荐了一些高级教程。学习任何一种编程语言都需要长期的坚持和不懈的努力,本文提醒读者要有足够的耐心和时间投入。通过实践操作学习,可以更好地理解和掌握PHP语言的特异性,特别是单引号和双引号的用法。同时,本文也指出了只走马观花看整体而不深入学习的学习方式无法真正掌握这门语言,建议读者要从整体来考虑局部,培养大局观。最后,本文提醒读者完成一个像模像样的网站需要付出更多的努力和实践。 ... [详细]
  • React基础篇一 - JSX语法扩展与使用
    本文介绍了React基础篇一中的JSX语法扩展与使用。JSX是一种JavaScript的语法扩展,用于描述React中的用户界面。文章详细介绍了在JSX中使用表达式的方法,并给出了一个示例代码。最后,提到了JSX在编译后会被转化为普通的JavaScript对象。 ... [详细]
  • 如何实现织梦DedeCms全站伪静态
    本文介绍了如何通过修改织梦DedeCms源代码来实现全站伪静态,以提高管理和SEO效果。全站伪静态可以避免重复URL的问题,同时通过使用mod_rewrite伪静态模块和.htaccess正则表达式,可以更好地适应搜索引擎的需求。文章还提到了一些相关的技术和工具,如Ubuntu、qt编程、tomcat端口、爬虫、php request根目录等。 ... [详细]
  • 本文介绍了如何将CIM_DateTime解析为.Net DateTime,并分享了解析过程中可能遇到的问题和解决方法。通过使用DateTime.ParseExact方法和适当的格式字符串,可以成功解析CIM_DateTime字符串。同时还提供了关于WMI和字符串格式的相关信息。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • 本文介绍了游戏开发中的人工智能技术,包括定性行为和非定性行为的分类。定性行为是指特定且可预测的行为,而非定性行为则具有一定程度的不确定性。其中,追逐算法是定性行为的具体实例。 ... [详细]
  • 本文详细介绍了MysqlDump和mysqldump进行全库备份的相关知识,包括备份命令的使用方法、my.cnf配置文件的设置、binlog日志的位置指定、增量恢复的方式以及适用于innodb引擎和myisam引擎的备份方法。对于需要进行数据库备份的用户来说,本文提供了一些有价值的参考内容。 ... [详细]
  • 本文主要介绍了MySQL中子查询的基本用法和三种用法,包括生成参考值、内层查询与外层查询的比较操作以及使用事件号在成绩表中找到学生的分数记录。通过详细解析子查询的实例,帮助读者更好地理解和应用子查询。 ... [详细]
author-avatar
雷雨点H
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有