有一种语言可以从诞生一直活跃到现在,有一个梦想从南四楼蔓延到北五楼再走向世界,有一种坚持可以从懵懂年少成长为干练成熟,有一本书可以温暖心灵彼岸,与数据库抨击撞出火花,有一个系统足以让你忘却时间,不回宿舍,只为了能成功运行,不出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. linux中查看现在使用的shell是ksh还是bash?以及怎样修改?

    查看系统支持的shell: cat  /etc/shells 查看现在使用的shell:  修改默认shell: 另外,修改了系统默认shell之后不会立即生效,之后再次登录系统修改的shell才会生 ...

  2. Servlet之文件上传

    上传表单中的注意事项: 表单 method 属性应该设置为 POST 方法,不能使用 GET 方法 表单 enctype 属性应该设置为multipart/form-data 下面的实例是借助于com ...

  3. 3.QT中QCommandLineParser和QCommandLineOption解析命令行参数

     1  新建项目 main.cpp #include <QCoreApplication> #include <QCommandLineParser> #include & ...

  4. React Native自动化测试

    大凡做软件开发,肯定会涉及到很多的测试,本地测试,Junit测试,用例测试等,今天就来说说RN的测试. React Native的官方代码仓库里有一些测试代码,你可以在贡献代码之后回归测试一下,以检测 ...

  5. 使用maven将项目打成jar包

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...

  6. UNIX网络编程——fcntl函数

    fcntl函数提供了与网络编程相关的如下特性: 非阻塞式I/O.  通过使用F_SETFL命令设置O_NONBLOCK文件状态标志,我们可以把一个套接字设置为非阻塞型. 信号驱动式I/O. 通过使用F ...

  7. shell脚本中调用另一个脚本的三种不同方法(fork, exec, source)

    fork ( /directory/script.sh) fork是最普通的, 就是直接在脚本里面用/directory/script.sh来调用script.sh这个脚本. 运行的时候开一个sub- ...

  8. 【UI 设计】PhotoShop基础工具 -- 移动工具

    还是学点美工的东西吧, 业余爱好   比学编程还难 PS版本 : PhotoShop CS6 1. 移动工具 (1) 工具栏和属性栏 工具栏 和 属性栏 : 左侧的是工具栏, 每选中一个工具, 在菜单 ...

  9. android官方技术文档翻译——Case 标签中的常量字段

    本文译自androd官方技术文档<Non-constant Fields in Case Labels>,原文地址:http://tools.android.com/tips/non-co ...

  10. Eclipse 创建 Maven 项目、Maven JavaWeb 项目

    Eclipse 创建 Maven 项目         新建一个maven项目          (默认)(如果不行第一个Create a simple ... 也选中) 默认         Jav ...