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

    单客户端,顾名思义,就是客户端只有一个用户去访问服务器,然后服务器根据该客户请求返回信息,先看下效果图: 服务端(左)和客户端(右): 注意,我是用了两个eclipse,一个只放服务端文件,一个只放客 ...

  2. 使用std::vector优化点云动画显示一例

    1. 准备 使用std::vector应该知道几点: (1)内存连续的容器,有点像数组 (2)与std::list相比,插入和删除元素比较慢- 因为数据迁移 (3)添加元素可能会引发内存分配和数据迁移 ...

  3. 剑指Offer——腾讯+360+搜狗校招笔试题+知识点总结

    剑指Offer--腾讯+360+搜狗校招笔试题+知识点总结 9.11晚7:00,腾讯笔试.选择题与编程.设计题单独计时. 栈是不是顺序存储的线性结构啊? 首先弄明白两个概念:存储结构和逻辑结构. 数据 ...

  4. 分布式缓存组件Hazelcast

    Hazelcast是一个Java的开源分布式内存实现,它具有以下特性: 提供java.util.{Queue, Set, List, Map}的分布式实现 提供java.util.concurrent ...

  5. SpringMVC实现用户登录实例

    今天分享一下SpringMVC的一个登陆小案例 准备工作 创建一个Dynamic Web Project(本人是Eclipse) 添加相关的jar包,构建路径 创建springMVC-servlet. ...

  6. 02_MyBatis项目结构,所需jar包,ehcache.xml配置,log4j.properties,sqlMapConfig.xml配置,SqlMapGenerator.xml配置

     项目结构(所需jar包,配置文件) sqlMapConfig.xml的配置内容如下: <?xmlversion="1.0"encoding="UTF-8&qu ...

  7. (一〇三)静态库(.a)的调试

    上节介绍的方法,只能创建静态库而不能调试,因为直接创建静态库工程并非可执行文件. 本文介绍的方法创建的静态库断点能够在调试时起作用. 为了能够调试静态库,应该在一个可执行工程(例如Single Vie ...

  8. Ubuntu15.10下制作Linux 操作系统优盘启动盘

    上次电脑出现了一些问题,于是不得不重新装机了.下面就跟大家分享一下我在Ubuntu下制作优盘启动盘的一些心得. 准备原料 我这里用到的是 镜像文件是:debian-8.3.0-amd64-DVD-2. ...

  9. SDL2源代码分析5:更新纹理(SDL_UpdateTexture())

    ===================================================== SDL源代码分析系列文章列表: SDL2源代码分析1:初始化(SDL_Init()) SDL ...

  10. mysql进阶(二十五)解决数据库NO CONNECTION问题

    解决数据库NO CONNECTION问题 前言 数据库版本类型:Mysql5.5 在应用程序连接数据库时,提示数据库连接失败.打开数据库查看,显示如下. 究其原因,是因为mysql服务出现了问题,重启 ...