热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

第二章SQLServer数据库表管理-mysql教程

数据库本身无法直接存储数据,存储数据是通过数据库中的表来实现的。2.1表相关的几个基本概念在创建和管理数据库表之前,需要理解以下几个概念。2.1.1数据完整性数据完整性是要求数据库中的数据具有准确性,准确性是通过数据库表的设计和约束来实现的

数据库本身无法直接存储数据,存储数据是通过数据库中的表来实现的。 2.1 表相关的几个基本概念 在创建和管理数据库表之前,需要理解以下几个概念。 2.1.1 数据完整性 数据完整性是要求数据库中的数据具有准确性,准确性是通过数据库表的设计和约束来实现的

  数据库本身无法直接存储数据,存储数据是通过数据库中的表来实现的。

2.1 表相关的几个基本概念

  在创建和管理数据库表之前,需要理解以下几个概念。

2.1.1 数据完整性

  数据完整性是要求数据库中的数据具有准确性,准确性是通过数据库表的设计和约束来实现的。例如:在存储学生信息的表中,如果允许任意输入学员信息的话,则在同一张表中可能重复出现一个学员的信息;还有如果不对表中存储的年龄信息加以限制,则学员出现的年龄可能出现负数,这样的数据都不具备完整性。

  为了实现完整性,数据库需要做以下两方面的工作。

    检验每行数据是否符合要求。

    检验每列数据是否符合要求。

  为实现以上要求,SQL Server提供了以下4种类型的约束(Constraint)。

  1. 实体完整性约束

    实体完整性要求表中的每一行数据都反映不同的实体,不能存在相同的数据行。

    通过索引、唯一约束、逐渐约束或标识列属性,可以实现表的实体完整性。

  2. 域完整性约束

    域完整性是指给定列的输入有效性。

    通过限制数据类型、检查约束、输入格式、外键约束、默认值、非空约束等多种方法,可以实现表的域完整性。

  3. 引用完整性约束

    在输入或删除数据行时,引用完整性约束用来保持表之间已定义的关系。

    例如:在管理学员信息的时候,一个表用来存储学员的信息,一个表用来存储考试成绩的详细情况,并且考试成绩表中的一列数值就是学员信息表中的编号,用来表示是哪个学员的考试。

  

    可以看出两张表建立了“关系”,学员信息表是“主表”,学员成绩表是“子表”(有时也叫做“相关表”)。

    在强制引用完整性时,SQL Server 禁止用户进行下列操作。

      当主表中没有关联的记录时,将记录添加到相关表中。也就是说学员成绩表中不能够出现在学员信息表中不存在的学号。

      更改主表中的值并导致相关表中的记录孤立。如果学员信息表中的学号改变了,学员成绩表中的学号也应当随之改变。

      从主表中删除记录,但仍存在与该记录匹配的相关记录。如果把学员信息表中的学员删除了,则该学员的学号不能出现在学员成绩表中。

    引用完整性通过逐渐和外键之间的引号关系来实现。

  4. 自定义完整性约束

推荐阅读
  • 本文介绍了多种将多行数据合并为单行的方法,包括使用动态SQL、函数、CTE等技术,适用于不同的SQL Server版本。 ... [详细]
  • SQLite是一种轻量级的关系型数据库管理系统,尽管体积小巧,却能支持高达2TB的数据库容量,每个数据库以单个文件形式存储。本文将详细介绍SQLite在Android开发中的应用,包括其数据存储机制、事务处理方式及数据类型的动态特性。 ... [详细]
  • 本文详细介绍了在 Windows 7 上安装和配置 PHP 5.4 的 Memcached 分布式缓存系统的方法,旨在减少数据库的频繁访问,提高应用程序的响应速度。 ... [详细]
  • 数据库环境:SQLSERVER2005  有一个test表,其表结构及数据如下图1。其中,id是主键,mid是当前节点,pid是父节点。要求:查出每个节点的根节点,如图2所示。 ... [详细]
  • 本文介绍了如何在Laravel框架中使用Select方法进行数据库查询,特别是当需要根据传入的分类ID查询相关产品时的正确做法和注意事项。 ... [详细]
  • 深入解析轻量级数据库 SQL Server Express LocalDB
    本文详细介绍了 SQL Server Express LocalDB,这是一种轻量级的本地 T-SQL 数据库解决方案,特别适合开发环境使用。文章还探讨了 LocalDB 与其他轻量级数据库的对比,并提供了安装和连接 LocalDB 的步骤。 ... [详细]
  • MySQL 8.0 新特性详解:免费视频教程上线
    本文介绍了一套在慕课网上发布的免费视频教程,深入解析 MySQL 8.0 的核心新功能,包括增强的安全性、用户管理、新的索引类型、CTE 和窗口函数等。 ... [详细]
  • 本文详细介绍了Oracle RMAN中的增量备份机制,重点解析了差异增量和累积增量备份的概念及其在不同Oracle版本中的实现。通过对比两种备份方式的特点,帮助读者选择合适的备份策略。 ... [详细]
  • SQL 数据恢复技巧:利用快照实现高效恢复
    本文详细介绍了如何在 SQL 中通过数据库快照实现数据恢复,包括快照的创建、使用及恢复过程,旨在帮助读者深入了解这一技术并有效应用于实际场景。 ... [详细]
  • 构建Python自助式数据查询系统
    在现代数据密集型环境中,业务团队频繁需要从数据库中提取特定信息。为了提高效率并减少IT部门的工作负担,本文探讨了一种利用Python语言实现的自助数据查询工具的设计与实现。 ... [详细]
  • 详解MyBatis二级缓存的启用与配置
    本文深入探讨了MyBatis二级缓存的启用方法及其配置细节,通过具体的代码实例进行说明,有助于开发者更好地理解和应用这一特性,提升应用程序的性能。 ... [详细]
  • 利用Git GUI将本地项目同步至GitHub的方法
    GitHub作为开发者不可或缺的工具,不仅提供了丰富的开源项目资源,还极大地便利了个人项目的管理和版本控制。本文将详细介绍如何使用Git GUI工具将本地开发的项目上传至GitHub。 ... [详细]
  • 本文将详细探讨MySQL中较为特殊的三种数据类型:SQLTEXT、DATE以及SET,包括它们的基本用法、适用场景及一些高级特性。 ... [详细]
  • StoredProcedure “存储过程名” 的TextHeader 中存在语法错误
    修改存储过程的时候出现StoredProcedure“存储过程名”的TextHeader中存在语法错误出现这样的问题的解决方法(本人修改已成功)在创建存 ... [详细]
  • 本文详细介绍了如何处理Oracle数据库中的ORA-00227错误,即控制文件中检测到损坏块的问题,并提供了具体的解决方案。 ... [详细]
author-avatar
love糸_603
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有