MySQL中的数据库对象
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中的数据库对象的更多相关文章
- 实验十--- MySQL过程式数据库对象
实验十 MySQL过程式数据库对象 一. 实验内容: 1. 存储过程的创建和调用 2. 存储函数的创建和调用 3. 触发器的创建和触发 4. 事件的创建和修改 一. 实验项目:员工管理数据库 用于 ...
- C# 利用mysql.data 在mysql中创建数据库及数据表
C# 利用mysql.data 在mysql中创建数据库及数据表 using System; using System.Collections.Generic; using System.Linq; ...
- mysql中影响数据库性能的因素讲解
mysql中影响数据库性能的因素讲解 在本篇文章中我们给大家讲述了mysql中影响性能的因素以及相关知识点内容,有兴趣的朋友参考下 关于数据库性能的故事 面试时多多少少会讲到数据库上的事情,“你对数据 ...
- MySQL 中的数据库名称、数据表名称、字段名称
如何查询Oracle,Sql Server,MySQL 中的数据库名称.数据表名称.字段名称 分类: Database2012-09-24 22:16 7034人阅读 评论(0) 收藏 举报 数据库s ...
- 在MySQL中保存Java对象
需要在MySQL中保存Java对象. 说明: 对象必须实现序列化 MySQL中对应字段设置为blob 将Java对象序列化为byte[] public static byte[] obj2byte(O ...
- 查询MySQL中某个数据库中有多少张表
SELECT COUNT(*) TABLES, table_schema FROM information_schema.TABLES WHERE table_schema = '数据库' GRO ...
- MySQL中information_schema数据库的内容
大家在安装或使用MYSQL时,会发现除了自己安装的数据库以外,还有一个information_schema数据库. information_schema数据库是做什么用的呢,使用WordPress博客 ...
- 关于RDS for mysql中导入数据库set global event_scheduler =1 需要更多超级权限
关于RDS中导入数据库set global event_scheduler =1 需要更多超级权限 报错提示 其实这个意思是 让mysql自动启动 计划任务 如果在 命令行下 查询 SHOW VAR ...
- 【MYSQL笔记3】MYSQL过程式数据库对象之存储过程的调用、删除和修改
mysql从5.0版本开始支持存储过程.存储函数.触发器和事件功能的实现. 我们以一本书中的例题为例:创建xscj数据库的存储过程,判断两个输入的参数哪个更大.并调用该存储过程. (1)调用 首先,创 ...
随机推荐
- 8.5 JavaScript的BOM(二)
8.5 JavaScript的BOM 即 浏览器对象模型(Browser Object Model) 浏览器对象包括 一.Window(窗口) 如果需要打开一个新的网站,应该通过超级链接等方式让用户主 ...
- 图书管理(单链表C++)
#include<iostream> #include<string> #include<iomanip> #include<fstream> usin ...
- Windows环境安装MySQL8.0.11
网络开发数据库是必不可少的.曾经安装个Mysql,但是忘了.再次安装还是得百度.那还不如自己写篇博客记录一下呢,以后再忘记就看自己的博客好 Mysql官网安装地址(windows环境): https: ...
- Redis 的配置
Redis 的配置文件位于 Redis 安装目录下,文件名为 redis.conf. 你可以通过 CONFIG 命令查看或设置配置项. 语法 Redis CONFIG 命令格式如下: redis 12 ...
- 搭建Django项目虚拟环境(Windows系统下)
一.安装virtualenv 我们可以使用正式的Python环境中的pip进行安装.进入cmd界面,运行“ pip install virtualenv ”,完成安装后,可以运行“ where vir ...
- MySQL5.7 创建及查看数据库
1.创建数据库语句create database语句是在MySQL实例上创建一个指定名称的数据库.create schema语句的语义和create database是一样的. 2.语法解析 CREA ...
- WebView加载html实现网页上传本地文件(图片,拍照,语音等)
前言: 这里有两个方案,第一个使用Andorid客户端和JavaScript互相调用方法来实现,这种方法极力不推荐,它会增加服务端和客户端的开发成本. 第二种就是继承WebViewChromeClie ...
- R语言与概率统计(六) 主成分分析 因子分析
超高维度分析,N*P的矩阵,N为样本个数,P为指标,N<<P PCA:抓住对y对重要的影响因素 主要有三种:PCA,因子分析,回归方程+惩罚函数(如LASSO) 为了降维,用更少的变量解决 ...
- Linux命令集锦:ansible命令
ansible 命令主要用于批量管理,来实现自动化管理.常用批量操作包括:主机分组管理.实时批量执行命令或脚本.实时批量分发文件或目录.定时同步文件等. 一.安装 ansible yum instal ...
- iOS模型输出和打印
在调试时,我们经常用到输出model,查看数据是否正确,还会在控制台"po 模型"操作,一般输出都是这样的格式的: person is <Person: 0x60800003 ...