1、数据库中一般包含下列对象

  表、约束、索引、触发器、序列、视图;

  可以使用图形用户界面或通过显式执行语句来创建这些数据库对象。用于创建这些数据库对象的语句称为“数据定义语言”(DDL),它们通常以关键字 CREATE 或 ALTER 作为前缀。

  了解每个数据库对象提供的特征和功能很重要,这有助于设计一个好的数据库,该数据库不仅要满足当前业务的数据存储需求,同时还应保持足够的灵活性,以便能随着时间的推移进行扩充和增长。

  (资料源于https://www.ibm.com/support/knowledgecenter/zh/SSEPGG_9.5.0/com.ibm.db2.luw.admin.dbobj.doc/doc/c0023321.html,数据库是DB2,不同的数据库有不同)

  2、表

  表是数据库管理器维护的逻辑结构。表由列和行组成。

  3、约束——用于优化的规则

  在任何业务中,数据通常必须符合特定限制或规则。例如,职员编号必须是 唯一的。数据库管理器提供了约束作为强制实施这种规则的方法。

  通常,数据库会提供以下类型的约束:

  • NOT NULL 约束:非空约束防止在列中输入空值。

  在排序时NULL值会出现在增序排序的首位,出现在减序排序的末位。

  NULL意味着“not having a value”:

  • DEFAULT约束:默认约束,赋予某字段默认值。如果该字段没有插入数据,则其值为默认值。
  • UNIQUE KEY:唯一约束:设置字段的值是唯一的,允许为空,但只能有一个空值。
  • PRIMARY KEY:主键约束,设置字段为表的主键,作为该表的唯一标识。
  • FOREIGN KEY:外键约束,也称为引用约束或引用完整性约束。在两表之间建立关系,指定引用主表的哪一字段。InnoDB支持外键,MyISAM不支持。还有,作为外键的字段要求在主表中是主键(单字段主键)。
  • AUTO_INCREMENT:设置为自增字段,且每条默认自增1;通常用于设置主键,且为整数类型;可设置初始值和步长。
  • (表)检查约束:指定表中每行的一列或多列中允许使用的值。指定检查约束是通过限制格式的搜索条件完成的。
  • 参考约束:参考约束是一种约束属性,SQL 编译器可使用它来改善对数据的访问。参考约束不是由数据库管理器强制执行的,并且不用于数据的附加验证;它们用来提高查询性能。

  4、索引

  索引是一个或多个键的集合,每个键指向表中的一行。SQL优化器自动选择最有效率的访问表中数据的方法。当确定最快速的数据访问路径时,优化器会将索引考虑在内。

  5、触发器

  触发器定义一组操作,在响应对指定表的插入、更新或删除操作时将执行这些操作。执行这样的 SQL 操作时,触发器被认为是已激活的。触发器是可选的,并且可使用 CREATE TRIGGER 语句定义。

  6、序列

  序列是一个数据库对象,它允许自动生成值,例如,支票号。

  序列特别适合于生成唯一键值这一任务。应用程序可以使用序列来避免用于跟踪数字的列值所引起的可能的并行性和性能问题。

  与在数据库外部创建的数字相比,序列的优点在于数据库服务器将跟踪生成的数字。崩溃和重新启动不会导致生成重复的数字。

  7、视图

  视图是高效率的数据呈示方法(无需维护数据)。视图不是实际的表,不需要永久存储器。“虚拟表”是即创建即使用的。

MySQL中的数据库对象的更多相关文章

  1. 实验十--- MySQL过程式数据库对象

    实验十 MySQL过程式数据库对象 一.  实验内容: 1. 存储过程的创建和调用 2. 存储函数的创建和调用 3. 触发器的创建和触发 4. 事件的创建和修改 一.  实验项目:员工管理数据库 用于 ...

  2. C# 利用mysql.data 在mysql中创建数据库及数据表

    C# 利用mysql.data 在mysql中创建数据库及数据表 using System; using System.Collections.Generic; using System.Linq; ...

  3. mysql中影响数据库性能的因素讲解

    mysql中影响数据库性能的因素讲解 在本篇文章中我们给大家讲述了mysql中影响性能的因素以及相关知识点内容,有兴趣的朋友参考下 关于数据库性能的故事 面试时多多少少会讲到数据库上的事情,“你对数据 ...

  4. MySQL 中的数据库名称、数据表名称、字段名称

    如何查询Oracle,Sql Server,MySQL 中的数据库名称.数据表名称.字段名称 分类: Database2012-09-24 22:16 7034人阅读 评论(0) 收藏 举报 数据库s ...

  5. 在MySQL中保存Java对象

    需要在MySQL中保存Java对象. 说明: 对象必须实现序列化 MySQL中对应字段设置为blob 将Java对象序列化为byte[] public static byte[] obj2byte(O ...

  6. 查询MySQL中某个数据库中有多少张表

    SELECT COUNT(*) TABLES, table_schema FROM information_schema.TABLES   WHERE table_schema = '数据库' GRO ...

  7. MySQL中information_schema数据库的内容

    大家在安装或使用MYSQL时,会发现除了自己安装的数据库以外,还有一个information_schema数据库. information_schema数据库是做什么用的呢,使用WordPress博客 ...

  8. 关于RDS for mysql中导入数据库set global event_scheduler =1 需要更多超级权限

    关于RDS中导入数据库set global event_scheduler =1 需要更多超级权限 报错提示 其实这个意思是 让mysql自动启动 计划任务 如果在 命令行下 查询  SHOW VAR ...

  9. 【MYSQL笔记3】MYSQL过程式数据库对象之存储过程的调用、删除和修改

    mysql从5.0版本开始支持存储过程.存储函数.触发器和事件功能的实现. 我们以一本书中的例题为例:创建xscj数据库的存储过程,判断两个输入的参数哪个更大.并调用该存储过程. (1)调用 首先,创 ...

随机推荐

  1. Flutter移动电商实战 --(13)ADBanner组件的编写

    1.AdBanner组件的编写 我们还是把这部分单独出来,需要说明的是,这个Class你也是可以完全独立成一个dart文件的.代码如下: 广告图片 class AdBanner extends Sta ...

  2. Linux字符编码默认为UTF-8,如出现乱码可设置为GBK

    Linux字符编码默认为UTF-8,如出现乱码可设置为GBK1.手动更改profile文件的命令: vi /etc/profile 也可以修改 /etc/sysconfig/i18n 文件,如 LAN ...

  3. Web服务器磁盘满深入解析及解决

    ########################################################## 硬盘显示被写满但是用du -sh /*查看时占用硬盘空间之和还远#小于硬盘大小问的 ...

  4. jwt扩展

    1.新建扩展类 package com.ireciting.uaaservice.config; import com.ireciting.uaaservice.pojo.TUser; import ...

  5. ObjectAnimator属性动画示例代码

    import android.animation.AnimatorSet; import android.animation.ObjectAnimator; import android.app.Ac ...

  6. Docker监控:最佳实践以及cAdvisor和Prometheus监控工具的对比

    在DockerCon EU 2015上,Brian Christner阐述了“Docker监控”的概况,分享了这方面的最佳实践和Docker stats API的指南,并对比了三个流行的监控方案:cA ...

  7. php上传文件夹 ​

    用过浏览器的开发人员都对大文件上传与下载比较困扰,之前遇到了一个php文件夹上传下载的问题,无奈之下自己开发了一套文件上传控件,在这里分享一下.希望能对你有所帮助. 以下是实例的部分脚本文件与代码: ...

  8. Performance Analysis of Logs (PAL) Tool

    Performance Analysis of Logs (PAL) Tool 背景 在众多的独立项目中,我们如何快速了解数据库(SQL Server)服务器的性能,以及数据库的基线情况是怎样的,或者 ...

  9. Kettle 排序记录的使用(Sort rows)

    排序行的步骤根据您指定的字段和它们是否应该按升序或降序排序当行数超过指定的排序大小(默认为100万行)时候,kettle必须使用临时文件排序行.步骤名称:名称在整个转换中应该是唯一的排序目录:默认当前 ...

  10. C++typedef的详细用法

    转自知乎的一段解释: 作者:知乎用户链接:https://www.zhihu.com/question/29798061/answer/144423125来源:知乎著作权归作者所有.商业转载请联系作者 ...