目录
什么是SQL
SQL 有如下的优点。
模式(schema)
主键
什么是SQL
SQL(发音为字母S-Q-L 或sequel)是Structured Query Language(结构化查询语言)的缩写。SQL 是一种专门用来与数据库沟通的语言。
与其他语言(如英语或Java、C、PHP 这样的编程语言)不一样,SQL中只有很少的词,这是有意而为的。设计SQL 的目的是很好地完成一项任务——提供一种从数据库中读写数据的简单有效的方法。
SQL 有如下的优点。
- SQL 不是某个特定数据库供应商专有的语言。几乎所有重要的DBMS都支持SQL,所以学习此语言使你几乎能与所有数据库打交道。
- SQL 简单易学。它的语句全都是由有很强描述性的英语单词组成,而且这些单词的数目不多。
- SQL 虽然看上去很简单,但实际上是一种强有力的语言,灵活使用其语言元素,可以进行非常复杂和高级的数据库操作。
标准SQL 由ANSI 标准委员会管理,从而称为ANSI SQL。所有主要的DBMS,即使有自己的扩展,也都支持ANSI SQL。各个实现有自己的名称,如PL/SQL、Transact-SQL 等。
模式(schema)
表具有一些特性,这些特性定义了数据在表中如何存储,包含存储什么样的数据,数据如何分解,各部分信息如何命名等信息。描述表的这组信息就是所谓的模式(schema),模式可以用来描述数据库中特定的表,也可以用来描述整个数据库(和其中表的关系)。
schema 可以使得不同的数据库的数据进行连接,可以在 A 数据库通过 schema 的方式查询 B 数据库的信息,甚至可以在 A 数据库中查询与 B 数据库中具有相同栏位值的信息。
select a.name from std.students a , com.employee b where a.name = b.name;
主键
表中的任何列都可以作为主键,只要它满足以下条件:
- 任意两行都不具有相同的主键值;
- 每一行都必须具有一个主键值(主键列不允许NULL 值);
- 主键列中的值不允许修改或更新;
- 主键值不能重用(如果某行从表中删除,它的主键不能赋给以后的新行)。
多个列作为主键。在使用多列作为主键时,上述条件必须应用到所有列,所有列值的组合必须是唯一的(但单个列的值可以不唯一)。