说SQL

简介:
     先说说什么叫SQL?大家反正都觉得这SQL和数据库有关,其实也不是这样的。SQL是一种结构化数据库查询语言,其发音为“sequel”或“S-Q-L”。尽管MICROSOFT以其特有的方式加入了所有权声明,但它在大多数据库应用中近乎成为一种标准。简言之,它是一种使用你选择的标准从数据库记录中选择某些记录的方法。
       因为它的重要所以我将会花一定的时间来讲它,前面的东西大家不说可能用这就会了,但这个一定要仔细的说。先回答大家一个疑问,学了SQL有什么用呢?现在常用的数据库软件是ms-sql,一般的服务器上都由它提供数据库服务,但哟于具有管理权限的帐号SA的默认密码是空的,且低版本的SQL由漏洞能直接获得密码。所以它也成为入侵的一种捷径(如果由漏洞的话)。介绍个软件MS-SOL Brower(SQL远程入侵软件),以后会由用的。在使用它时,只需要发出“做什么”的 命令,“怎么做”是不用使用者考虑的。

SQL数据库数据体系结构

       SQL数据库的数据体系结构基本上是三级结构,但使用术语与传统关系模型术语不同。在SQL中,关系模式(模式)称为“基本表”(base table);存储模式(内模式)称为“存储文件”(stored file);子模式(外模式)称为“视图”(view);元组称为“行”(row);属性称为“列”(column)。名称对称如^00100009a^:
 
SQL语言的组成

在正式学习SQL语言之前,首先让我们对SQL语言有一个基本认识,介绍一下SQL语言的组成: 
1.一个SQL数据库是表(Table)的集合,它由一个或多个SQL模式定义。 
2.一个SQL表由行集构成,一行是列的序列(集合),每列与行对应一个数据项。 
3.一个表或者是一个基本表或者是一个视图。基本表是实际存储在数据库的表,而视图是由若干基本表或其他视图构成的表的定义。 
4.一个基本表可以跨一个或多个存储文件,一个存储文件也可存放一个或多个基本表。每个存储文件与外部存储上一个物理文件对应。 
5.用户可以用SQL语句对视图和基本表进行查询等操作。在用户角度来看,视图和基本表是一样的,没有区别,都是关系(表格)。 
6.SQL用户可以是应用程序,也可以是终端用户。SQL语句可嵌入在宿主语言的程序中使用,宿主语言有FORTRAN,COBOL,PASCAL,PL/I,C和Ada语言等。SQL用户也能作为独立的用户接口,供交互环境下的终端用户使用。 
(这个内容好像很难懂,大家如果实在不行,了解就行了)
 
对数据库进行操作

SQL包括了所有对数据库的操作,主要是由4个部分组成: 
1.数据定义:这一部分又称为“SQL DDL”,定义数据库的逻辑结构,包括定义数据 
库、基本表、视图和索引4部分。 
2.数据操纵:这一部分又称为“SQL DML”,其中包括数据查询和数据更新两大类操 
作,其中数据更新又包括插入、删除和更新三种操作。 
3.数据控制:对用户访问数据的控制有基本表和视图的授权、完整性规则的描述,事务控制语句等。 
4.嵌入式SQL语言的使用规定:规定SQL语句在宿主语言的程序中使用的规则
 
下面我们就 简单介绍一下数据定义

SQL数据定义功能包括定义数据库、基本表、索引和视图。 
首先,让我们了解一下SQL所提供的基本数据类型:(如^00100009b^) 
1.数据库的建立与删除 
(1)建立数据库:数据库是一个包括了多个基本表的数据集,其语句格式为: 
CREATE DATABASE <数据库名> [其它参数]其中,<数据库名>在系统中必须是唯一的,不能重复,不然将导致数据存取失误。[其它参数]因具体数据库实现系统不同而异。 
例:要建立项目管理数据库(xmmanage),其语句应为: 
CREATE DATABASE xmmanage 
(2) 数据库的删除:将数据库及其全部内容从系统中删除。 
其语句格式为:DROP DATABASE <数据库名> 
例:删除项目管理数据库(xmmanage),其语句应为: 
DROP DATABASE xmmanage 
2.基本表的定义及变更 
本身独立存在的表称为基本表,在SQL语言中一个关系唯一对应一个基本表。基本表的定义指建立基本关系模式,而变更则是指对数据库中已存在的基本表进行删除与修改。 
(1)基本表的定义:基本表是非导出关系,其定义涉及表名、列名及数据类型等,其语句格式为: 
CREATE TABLE[<数据库名>.]<表名> 
(<列名> 数据类型 [缺省值] [NOT NULL / NULL] 
[,<列名> 数据类型 [缺省值] [NOT NULL / NULL]]...... 
[,UNIQUE (列名[,列名]......)] 
[,PRIMARY KEY(列名)] 
[,FOREIGN KEY(列名[,列名]......)REFERENCE <表名>(列名[,列名] 
......)] 
[,CHECK(条件)] [其它参数]) 
其中,〈数据库名〉.]指出将新建立的表存放于该数据库中; 
新建的表由两部分组成:其一为表和一组列名,其二是实际存放的数据(即可在定义表的同时,直接存放数据到表中);列名为用户自定义的易于理解的名称,列名中不能使用空格;数据类型为上面所介绍的几种标准数据类型; 
[NOT NULL/NULL]指出该列是否允许存放空值,SQL语言支持空值的概念,所谓空值是“不知道”或“无意义”的值,值得注意的是数据“0”和空格都不是空值,系统一般默认允许为空值,所以当不允许为空值时,必须明确使用NOT NULL;[,UNIQUE]将列按照其规定的顺序进行排列,如不指定排列顺序,则按列的定义顺序排列;[PRIMARY KEY]用于指定表的主键(即关系中的主属性),实体完整性约束条件规定:主键必须是唯一的,非空的; 
[,FOREIGN KEY (列名[,列名]......) REFERENCE<表名>(列名[,列名]......)]是用于指定外键参照完整性约束条件,FOREIGN KEY指定相关列为外键,其参照对象为另外一个表的指定列,即使用REFERENCE引入的外表中的列,当不指定外表列名时,系统将默认其列名与参照键的列名相同,要注意的是:使用外键时必须使用参照,另外数据的外键参照完整性约束条件规定:外键的值要么与相对应的主键相同,要么为空值(具体由实现系统不同而异) [,CHECK]用于使用指定条件对存入表中的数据进行检查,以确定其合法性,提高数据的安全性。 
2)基本表的删除:用以从数据库中删除一个基本表及其全部内容,其语句格式为:DROP TABLE[<数据库名>.]表名 
(3)基本表的修改:在基本表建立并使用一段时间后,可能需要根据实际要求对基本表的结构进行修改,即增加新的属性或删除属性。 
增加属性的语句格式为: 
ALTER TABLE [<数据库名>.]表名 ADD 
(<列名> 数据类型 [缺省值] [NOT NULL / NULL] 
[,<列名> 数据类型[缺省值][NOT NULL / NULL]]...... 
[,UNIQUE (列名[,列名]......)] 
[,PRIMARY KEY(列名)] 
[,FOREIGN KEY(列名[,列名]......) REFERENCE <表名>(列名[,列名]......)] 
[,CHECK(条件)][其它参数]) 
例如:在基本表student中加入列stborn出生日期,数据类型为DATE,且不能为空值ALTER TABLE student ADD (stborn DATE NOT NULL) 删除属性的语句格式为:ALTER TABLE [<数据库名>.]表名 DROP ( <列名> 数据类型 [缺省值][NOT NULL / NULL][,<列名> 数据类型 [缺省值][NOT NULL / NULL]]......) 
3.视图定义与删除 
在SQL中,视图是外模式一级数据结构的基本单位。它是从一个或几个基本表中导出的表,是从现有基本表中抽取若干子集组成用户的“专用表”。这种构造方式必须使用SQL中的SELECT语句来实现。在定义一个视图时,只是把其定义存放在系统的数据中,而并不直接存储视图对应的数据,直到用户使用视图时才去求得对应的数据。
(1)视图的定义:定义视图可以使用CREATE VIEW语句实现,其语句格式为: 
CREATE VIEW 视图名 AS SELECT语句
(2)视图的删除:用于删除已不再使用的视图,其语句格式如下: DROP VIEW 视图名
 
数据控制

由于数据库管理系统是一个多用户系统,为了控制用户对数据的存取权利,保持数据的共享及完全性,SQL语言提供了一系列的数据控制功能。其中,主要包括安全性控制、完整性控制、事务控制和并发控制。这个我就不详细说明了,大家如果有兴趣可以参阅相关书籍大概需要掌握的SQL基本类容就是这样,因为里面涉及到一些语法和语言,如果你没有一点语言基础的我想会很困难的,我只能建议你去至少看看C语言。


本文转自 zhouhaipeng 51CTO博客,原文链接:http://blog.51cto.com/zhouhaipeng/102756,如需转载请自行联系原作者

相关文章
|
6月前
|
SQL 网络协议 数据库
sql总结喔
sql总结喔
|
9月前
|
SQL Oracle 关系型数据库
sql
sql
68 0
|
9月前
|
SQL 程序员 数据库
sql 总结
一对多:在多的表中添加建立关系的字段(外键)指向另外一张表。如果需要查询一张表的全部和另外一张表的交集时,使用外连接,连表查询(左外连接)(显示左表的全部信息和右表相关联的信。连表查询(右外连接)(显示右表的全部信息和左表相关联的信。等值连接和内连接查询的是两个表的交集数据,推荐使用内连接。:选择插入必须选择需要插入的字段,选择对应字段的值,批量。查询所有部门的名称,地点和对应的员工姓名和工资。等值连接和内连接查询到的都是两张表的交集数据。外连接查询的是一张表的全部和另外一张表的交集。
85 0
|
SQL Oracle 关系型数据库
一个需求的三种实现(sql)
一个需求的三种实现(sql)
一个需求的三种实现(sql)
|
存储 SQL NoSQL
SQL必知必会(一)
对于我们而言,数据库是一个以某种有组织的方式存储的数据集合。最简单的办法就是将数据库想象成一个文件柜。这个文件柜是一个存放数据的物理位置,不管数据是什么,也不管数据是如何组织的。 数据库(DataBase) 保存有组织数据的容器(通常为一个或一组文件)
|
SQL 存储 搜索推荐
几个SQL问题
几个SQL问题
115 0
|
SQL
SQL日常
SQL日常
98 0
|
SQL 存储 监控
xttdbopen.sql
connect / as sysdba; alter database mount;alter database open; exit
735 0