有一种语言可以从诞生一直活跃到现在,有一个梦想从南四楼蔓延到北五楼再走向世界,有一种坚持可以从懵懂年少成长为干练成熟,有一本书可以温暖心灵彼岸,与数据库抨击撞出火花,有一个系统足以让你忘却时间,不回宿舍,只为了能成功运行,不出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 是一门美丽的语言 她来自艺术的更多相关文章

  1. C语言究竟是一门怎样的语言?

    对于大部分程序员,C语言是学习编程的第一门语言,很少有不了解C的程序员. C语言除了能让你了解编程的相关概念,带你走进编程的大门,还能让你明白程序的运行原理,比如,计算机的各个部件是如何交互的,程序在 ...

  2. (二)Python是一门什么样的语言?

    在学习python是一门什么样的语言之前首先需要知道什么是编译和解释? 编译器是把源程序的每一条语句都编译成机器语言,并保存成二进制文件,这样运行时计算机可以直接以机器语言来运行此程序,速度很快; 而 ...

  3. PHP 是一门弱类型语言

    PHP 是一门弱类型语言 我们注意到,不必向 PHP 声明该变量的数据类型. PHP 会根据变量的值,自动把变量转换为正确的数据类型. 在强类型的编程语言中,我们必须在使用变量前先声明(定义)变量的类 ...

  4. SQL中的四种语言DDL,DML,DCL,TCL

    1.DDL(Data Definition Language)数据库定义语言statements are used to define the database structure or schema ...

  5. ORA-01843: 无效的月份,执行sql语句更改为美国语言后仍然失败的解决办法

    ORA-01843: 无效的月份失败的 sql 为:XXXXXXXXXXXXXXXX 执行sql语句更改为美国语言后仍然失败, ALTER SESSION SET NLS_DATE_LANGUAGE= ...

  6. Python 笔试集(3):编译/解释?动态/静态?强/弱?Python 是一门怎样的语言

    面试题 解释/编译?动态/静态?强/弱?Python 到底是一门怎样的语言? 编译 or 解释? 编译.解释都是指将(与人类亲和的)编程语言翻译成(计算机能够理解的)机器语言(Machine code ...

  7. Swift - 语言指南,来自github学习

    @SwiftLanguage 更新于 2016-6-6,更新内容详见 Issue 55.往期更新回顾详见<收录周报> 这份指南汇集了 Swift 语言主流学习资源,并以开发者的视角整理编排 ...

  8. SQL于DML(数据库操作语言)采用

    1.Insert语句: INSERT [INTO] table [(column1, column2, column3, . . .)] VALUES(value1, value2, value3, ...

  9. Python是一门什么样的语言

    先做个总结:Python是一门动态解释型的强类型定义语言. 那何为动态?何为解释?何为强类型呢? 我们需要了解编译型和解释型.静态语言和动态语言.强类型定义语言和弱类型定义语言这6个概念就可知晓. 编 ...

随机推荐

  1. java创建对象详解和多态问题

    一. java 构造方法不等于创建对象而是初始化对象,new 关键字分配内存和创建对象的.  二.Test test = new Test(); 有人用上面的表达式来说明构造方法返回对象引用,这是明显 ...

  2. Python模块探秘之smtplib,实现纯文本邮件的发送

    今天学到了如何使用Python的smtplib库发送邮件,中间也是遇到了各种各样的错误和困难,还好都一一的解决了.下面来谈一谈我的这段经历. 配置你的邮箱 为什么要配置邮箱呢?具体要配置什么呢? 因为 ...

  3. (一一〇)正则表达式的基本使用与RegexKitLite的使用

    正则表达式常常用于匹配关键字,下面先介绍基本语法. [基本语法] ①中括号表示满足其中之一即可,例如[abc],则这个位置可以是a.b.c中任意一个. ②在中括号中,可以通过-连接范围,例如a-z:多 ...

  4. Android开发学习之路--网络编程之xml、json

    一般网络数据通过http来get,post,那么其中的数据不可能杂乱无章,比如我要post一段数据,肯定是要有一定的格式,协议的.常用的就是xml和json了.在此先要搭建个简单的服务器吧,首先呢下载 ...

  5. [C++学习历程]中级部分 OpenGL第一个例子实现

    作者:sushengmiyan 本文地址:http://blog.csdn.net/sushengmiyan/article/details/21488231 环境:VS2010 准备工作: 1.下载 ...

  6. xml的今生今世

    跟随小编学习的脚步,今天小编来简单总结一下xml的今生今世,xml百度百科对她这样诠释到:可扩展标记语言 (ExtensibleMarkup Language, XML),用于标记电子文件使其具有结构 ...

  7. MyBatis主键生成器SelectKeyGenerator(三)

    前面两篇博客我们介绍了MyBatis主键生成器KeyGenerator(一)和MyBatis主键生成器Jdbc3KeyGenerator(二),接下来我们介绍SelectKeyGenerator, 如 ...

  8. iOS中 加强日志输出 开发技术总结

    对于那些做后端开发的工程师来说,看LOG解Bug应该是理所当然的事,但我接触到的移动应用开发的工程师里面,很多人并没有这个意识,查Bug时总是一遍一遍的试图重现,试图调试,特别是对一些不太容易重现的B ...

  9. cocos2D v3.4 在TileMap中开启高清显示

    在Tiled中制作一幅地图,用的图片砖块分辨率为32x32. iOS设备为iPhone 4s. 在未打开高清屏支持的cocos2d v2.x版本中,运行log显示480x320.遂启用高清屏支持: [ ...

  10. 你可能不知道的5种 CSS 和 JS 的交互方式

    翻译人员: 铁锚 翻译日期: 2014年01月22日 原文日期: 2014年01月20日 原文链接:  5 Ways that CSS and JavaScript Interact That You ...