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

  1. INSERT --向数据库表添加新数据行
  2. DELETE --从数据库表中删除数据行
  3. 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. P2P系统,一致性哈希和DHT

    数据网格产品经常会使用P2P进行通信,借此机会系统地学习一下P2P网络和其资源搜索策略. 1 P2P网络架构 谈到P2P就涉及到一个概念:Overlay Network(覆盖网络).所谓覆盖网络是应用 ...

  2. DOM4J生成、解析XML实例

    import java.io.File; import java.io.FileWriter; import java.io.IOException; import java.util.Iterato ...

  3. 百度地图SDK3.4的使用

    使用过百度地图的开发者应该都知道原始百度地图的开发的基本流程,但是随着百度地图的更新,百度地图的api有了翻天覆地的变化,最新版本的sdk为v3.4 2015年4月14日上线,优化了许多接口的设计,简 ...

  4. java中遍历map的几种方法介绍

          喜欢用Java写程序的朋友都知道,我们常用的一种数据结构map中存储的是键值对,我们一般存储的方式是: map.put(key, value); 而提取相应键的值用的方法是: map.ge ...

  5. HDU2612---(两次BFS)

    Description Pass a year learning in Hangzhou, yifenfei arrival hometown Ningbo at finally. Leave Nin ...

  6. JUI/DWZ介绍、简单使用

    简介 由于开发的项目使用JUI,所以学习了. DWZ富客户端框架(jQuery RIAframework), 是中国人自己开发的基于jQuery实现的Ajax RIA开源框架.(现在更名为JUI) 可 ...

  7. iOS中 基于LBXScan库二维码扫描 韩俊强的博客

    每日更新关注:http://weibo.com/hanjunqiang  新浪微博 首先声明这个二维码扫描是借助于zxing. 功能模块都完全封装好了,不过界面合你口味,直接使用就好,如果不合口味,后 ...

  8. 如何在Cocos2D游戏中实现A*寻路算法(三)

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请告诉我,如果觉得不错请多多支持点赞.谢谢! hopy ;) 免责申明:本博客提供的所有翻译文章原稿均来自互联网,仅供学习交流 ...

  9. Gradle 笔记——Java构建入门

    Gradle是一个通用的构建工具,通过它的构建脚本你可以构建任何你想要实现的东西,不过前提是你需要先写好构建脚本的代码.而大部分的项目,它们的构建流程基本是一样的,我们不必为每一个工程都编写它的构建代 ...

  10. Linux IPC实践(2) --匿名PIPE

    管道概念 管道是Unix中最古老的进程间通信的形式,我们把从一个进程连接到另一个进程的一个数据流称为一个"管道", 管道的本质是固定大小的内核缓冲区; 如:ps aux | gre ...