SQL 是一门美丽的语言 她来自艺术
有一种语言可以从诞生一直活跃到现在,有一个梦想从南四楼蔓延到北五楼再走向世界,有一种坚持可以从懵懂年少成长为干练成熟,有一本书可以温暖心灵彼岸,与数据库抨击撞出火花,有一个系统足以让你忘却时间,不回宿舍,只为了能成功运行,不出bug,有一种声音可以让你找到共鸣,想要赶快看完,敲机房,有一门语言她来自艺术,她----SQL。
当今社会,信息新潮技术层出不穷,数据库处理仍然处于我们系统的核心地位,并且需要管理的数据量的增长速度似乎比处理器增长速度还快,今天最重要的集团数据都被保存在数据库中,通过SQL语言来访问,SQL语言自从诞生以来,就非常流行,她从1980年代早期开始被广泛接受,现在我们就来简单总结一下标准的SQL包含哪几种语句。
数据查询 select
select语句从数据库中检索数据,然后以一个或多个结果集的形式返回给用户,结果集是一种表形式,由行和列组成,他可以直接显示,也可以组成数据库的新表。 select语句的基本结构如下:
select [all | distinct] select_list [ into [ new_table_name ] ] from { table_name | view_name } [ [, {table_name2 | view_name2} [ ...., { table_name16 | view_name16 } ] ] [ where
search_conditions ] [group by group_by_list] [ having search_conditions ] [ order by order_list [ asc | desc ] ]
数据定义 create drop alter
如果对数据进行查询,添加,修改等各项操作,则应先运行sql数据定义语言定义表,索引和视图。
a 创建表
表的创建是后面一切操作的基础,是建立数据库最重要的一步。
CTEATE TABLE <表名>
(<字段名><数据类型>[列级完整性约束条件][,<字段名><数据类型>[列级完整性约束条件]]…[,<表级完整性约束条件>]);
该命令创建名为<表名>的基表,并给出所有字段的<字段名>、<数据类型>和[列级完整性约束条件]以及<表级完整性约束条件>。
b 修改和扩充基表
ALTER TABLE<表名>[ADD[<新字段名><数据类型>[完整性约束]
| PRIMARY KEY(<字段名表>)|
FOREIGN KEY [(<外来关键字名>)](<字段名表>)REFERENCES<表名2>][ON
DELETE {CASCADE | RESTRICT | SET NULL}]][DROP [<完整性约束>{ CASCADE | RESTRICT} | PRIMARY KEY | FOREIGN KEY]][MODIFY<字段名><数据类型>];
该命令为添加、删除或修改表名为<表名>的字段、主键、外键。
其中<表名>是所要修改的基表名。ADD子句用于增加新字段、新的完整性约束条件、新主键、新外键;DROP子句用于删除指定的字段、完整性约束、主键、外键;MODIFY子句用于修改原有的字段定义,包括修改字段名和数据类型。<表名2>是外来关键字出处表名,即主表名。外来关键字在<表名>中不是关键字,但在<表名2>中是关键字。
DROP后的{
CASCADE | RESTRICT }表示删除字段时,若用CASCADE则引用该字段的所有视图和约束都一并删除;若用RESTRICT则当有视图或约束引用该字段时,不允许删除该字段。
完整性任选项[ON DELETE {CASCADE | RESTRICT | SET NULL}]用于删除外来关键字中,它说明当删除主表中被引用的关键字时,为了保证完整性可采用三种方法处理:
(1)用CASCADE,即当主表<表名2>中的某个关键字被删除时,在基表<表名>中引用了该外来关键字的对应记录随之被删除。
(2)选用RESTRICT,即被基表<表名>的外来关键字所引用的主表<表名2>中的主关键字不得删除。
(3)选用SET
NULL,即当主表<表名2>中的某个关键字被删除时,在基表<表名>中将引用了该外来关键字的对应记录的外来关键字值设为空值。
c 删除表
当某个表不再需要时,应当及时删除,以节省空间和减少出错等问题。用DROP
TABLE<表名>[CASCADE | RESTRICT] 来删除以前建的表<表名>。表一旦删除,表中的数据、该表上建立的索引都将自动被删除。另外,有的系统如Oracle,删除表后建立在该表上的视图仍然保留在数据字典中,但用户引用时就出错,所以还需手动删除相应所有视图。为了防止误操作,可以根据需要选用任选项CASCADE(级联式)或RESTRICT(约束式),当采用CASCADE时,在删除表时,该表中的数据、表本身以及在该表上所建的索引和视图将全部随之消失;当采用RESTRICT时,只有在先清除了表中的全部记录行数据以及在该表上所建的索引和视图后,才能删除表。
数据操纵insert update delete
SELECT
--从数据库表中检索数据行和列
INSERT --向数据库表添加新数据行
DELETE --从数据库表中删除数据行
UPDATE --更新数据库表中的数据
数据控制grant revoke
Grant和revoke主要是给表、视图、列上分配或失去权限的
一、grant 格式:
使用grant授予用户各种权限 Grant 角色 on 表名/视图 to 用户 ,用户:public guest ,角色:select update delete insert ,例如: 公司允许用户名为guest的客户,拥有对视图message进行select权限
, Grant select on message to guest 授予所有用户 ,Grant select on message to public 授权仅限字段 ,Grant update(grade) on sc to guest .
二、revoke
Guest撤销sc在grade中的更新权限 Revoke update on sc from grade, 备份数,BACKUDATABASENorthwindTO DISK = 'e:\Northwind1.bak' 还原数据库 ,RESTORE DATABASE student
FROM DISK = 'e:\student' .
SQL 是一门美丽的语言 她来自艺术的更多相关文章
- C语言究竟是一门怎样的语言?
对于大部分程序员,C语言是学习编程的第一门语言,很少有不了解C的程序员. C语言除了能让你了解编程的相关概念,带你走进编程的大门,还能让你明白程序的运行原理,比如,计算机的各个部件是如何交互的,程序在 ...
- (二)Python是一门什么样的语言?
在学习python是一门什么样的语言之前首先需要知道什么是编译和解释? 编译器是把源程序的每一条语句都编译成机器语言,并保存成二进制文件,这样运行时计算机可以直接以机器语言来运行此程序,速度很快; 而 ...
- PHP 是一门弱类型语言
PHP 是一门弱类型语言 我们注意到,不必向 PHP 声明该变量的数据类型. PHP 会根据变量的值,自动把变量转换为正确的数据类型. 在强类型的编程语言中,我们必须在使用变量前先声明(定义)变量的类 ...
- SQL中的四种语言DDL,DML,DCL,TCL
1.DDL(Data Definition Language)数据库定义语言statements are used to define the database structure or schema ...
- ORA-01843: 无效的月份,执行sql语句更改为美国语言后仍然失败的解决办法
ORA-01843: 无效的月份失败的 sql 为:XXXXXXXXXXXXXXXX 执行sql语句更改为美国语言后仍然失败, ALTER SESSION SET NLS_DATE_LANGUAGE= ...
- Python 笔试集(3):编译/解释?动态/静态?强/弱?Python 是一门怎样的语言
面试题 解释/编译?动态/静态?强/弱?Python 到底是一门怎样的语言? 编译 or 解释? 编译.解释都是指将(与人类亲和的)编程语言翻译成(计算机能够理解的)机器语言(Machine code ...
- Swift - 语言指南,来自github学习
@SwiftLanguage 更新于 2016-6-6,更新内容详见 Issue 55.往期更新回顾详见<收录周报> 这份指南汇集了 Swift 语言主流学习资源,并以开发者的视角整理编排 ...
- SQL于DML(数据库操作语言)采用
1.Insert语句: INSERT [INTO] table [(column1, column2, column3, . . .)] VALUES(value1, value2, value3, ...
- Python是一门什么样的语言
先做个总结:Python是一门动态解释型的强类型定义语言. 那何为动态?何为解释?何为强类型呢? 我们需要了解编译型和解释型.静态语言和动态语言.强类型定义语言和弱类型定义语言这6个概念就可知晓. 编 ...
随机推荐
- Java基本语法-----java数据类型的转换
前言 Java中可以进行不同数据类型的加减乘除运算吗?是可以的.在算术运算符中已经体验过如果两个整数(int)相除会去掉小数部分.如果需要保留小数部分,可以让除数或者被除数变为double类型的(5变 ...
- Android View框架总结(六)View布局流程之Draw过程
请尊重分享成果,转载请注明出处: http://blog.csdn.net/hejjunlin/article/details/52236145 View的Draw时序图 ViewRootImpl.p ...
- FFmpeg源代码简单分析:结构体成员管理系统-AVOption
===================================================== FFmpeg的库函数源代码分析文章列表: [架构图] FFmpeg源代码结构图 - 解码 F ...
- GSON TypeToken 解决泛型问题
Java进阶(四)Java反射TypeToken解决泛型运行时类型擦除的问题解决 在开发时,遇到了下面这条语句,不懂,然习之. private List<MyZhuiHaoDetailModel ...
- 最简单的基于librtmp的示例:发布H.264(H.264通过RTMP发布)
===================================================== 最简单的基于libRTMP的示例系列文章列表: 最简单的基于librtmp的示例:接收(RT ...
- Mybatis简单入门
MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以使用简单的XML或注解用 ...
- Activity与Fragment的生命周期详解
在安卓中Activity与Fragment是非常相似的两个类,它们各自都拥有自己的生命周期,且都可以用来显示布局文件中的视图.其中Activity是通过setContenView()显示视图,而Fra ...
- 给你的流添加缓冲装置——字节块ByteChunk
这是一个很重要的一个字节数组处理缓冲工具,它封装了字节缓冲器及对字节缓冲区的操作,包括对缓冲区的写入.读取.扩展缓冲区大小等等,另外还提供相应字符编码的转码操作.此工具让缓冲操作变得更加方便,除了缓冲 ...
- JSP标签JSTL的使用(1)--表达式操作
单纯的使用jsp脚本来进行逻辑处理,显得代码很是杂乱.为了更加简洁也为了便于代码的阅读,于是JSTL应运而生. 库文件下载地址: 我自己上传的一份压缩文件,里面包含了所有需要的jar包,而且不需要积分 ...
- Java进阶(二十九)Could not create the view: An unexpected exception was thrown
Could not create the view: An unexpected exception was thrown 在将web项目部署到tomcat时,控制台输出以下内容: 这个问题的出现是在 ...