SQL概念

SQL全称(Structured Query Language):结构化查询语句,是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询和管理关系型数据库。

其实就是定义了所有关系型数据库的规则。但是每一种数据库的sql语句操作方式存在不一样的地方,也把这种不一样的地方称为该数据库的'方言'

SQL通用语句

  1. SQL语句可以单行或多行书写,以分号结尾
  2. 可以使用空格和缩进来增强语句的可读性
  3. MySQL数据库的SQL 语句不区分大小写, 关键字建议大写
  4. 注释
    • 单行注释: -- 注释内容 (--后要加空格) 或 # 注释内容(mysql特有)
    • 多行注释: /* 注释内容 */

SQL语句分类

  1. DDL(Data Definition Language): 数据定义语言

    • 用来定义数据库对象:数据库,表,列等。 关键字:create,drop, alter等。
  2. DML(Data Manipulation Language): 数据操作语言
    • 用来对数据库中的表进行增删改操作。 关键字:insert,delete,update等。
  3. DQL(Data Query Language): 数据查询语言
    • 用来查询数据库中表的记录(数据)。 关键字:select, where等
  4. DCL(Data Control Language): 数据控制语言
    • 用来定义数据库的访问控制权限和安全级别,及创建用户。关键字: grant, revoke等

DDL: 操作数据库、表

  1. 操作数据库:CRUD(增删改查)

    1. C(Create): 创建

      • 创建数据库: CREATE DATABASE 数据库名称;
      • 创建数据库,判断是否存在,不存在则创建:CREATE DATABASE IF NOT EXISTS 数据库名称;
      • 创建数据库并指定其字符集: CREATE DATABASE 数据库名称 CHARACTER SET 字符集;

        示例:
          CREATE DATABASE IF NOT EXISTS dbName CHARACTER SET gbk;
    2. R(Retrieve): 查询

      • 查询所有数据库的名称: SHOW DATABASES;

        示例:

      • 查询某个数据库的创建语句: SHOW CREATE DATABASE 数据库名称;

        示例:

      从上图可以看出,在查询数据库创建语句时,也可以看到数据库的字符集,所以通过该语句也可以看出数据库的字符集

    3. U(Update): 修改

      • 修改数据库的字符集: ALTER DATABASE dbName CHARACTER SET 字符集名称;

        示例:

    4. D(Delete): 删除

      • 删除数据库: DROP DATABASE 数据库名称;
      • 判断数据库存在,存在则删除: DROP DATABASE IF EXISTS 数据库名称;
    5. 使用数据库

      只有使用了数据库,才能对数据库里面的表等进行操作。若没有使用某一个数据库,而直接对其表进行操作,这样会发生错误,SQL语句并不会执行。

      • 查询当前正在使用的数据库名称: select database();

        示例:

      NULL代表了当前没有使用任何数据库,

      • 使用数据库: USE 数据库名称;
  2. 操作表

    1. C(Create): 创建

      • 语法:
          CREATE TABLE tableName(
      列名1 数据类型1,
      列名2 数据类型2,
      ....
      列名n 数据类型n,
      [添加约束...]
      );
      • 注意:最后一行不用加逗号(,);加了就会报错
      • 数据库中常用的数据类型:
        1. 整数类型: int, bigint 等
        2. 浮点数: float,double,decimal 浮点数可以指定精度 如decimal(11,2) 代表了该浮点数的长度为11位,小数位只保留2位
        3. 日期类型:
          • date: 只包含年月日 yyyy-MM-dd;
          • datetime: 包含年月日时分秒 yyyy-MM-dd HH:mm:ss;
          • timestamp: 时间戳类型 包含年月日时分秒 yyyy-MM-dd HH:mm:ss; 如果在插入数据时,不给时间戳类型赋值,或赋值为null,则默认使用当前的系统时间,来自动赋值。并且只要对该类型所在的行进行CUD(增删改)操作,这个类型的字段会自动更新成当前系统时间
        4. 字符串类型: varchar 如: password varchar(16) 指定该字段的最大字符
      • 创建表示例:

        CREATE TABLE student(
        stu_id INT(32),
        stu_name VARCHAR(20),
        stu_age INT,
        stu_score DECIMAL(4,1),
        stu_birthday DATE,
        insert_time TIMESTAMP
        );
      • 复制表: CREATE TABLE 表名 like 被复制的表名;
    2. R(Retrieve): 查询
      • 查询某个数据库中所有表名称: SHOW TABLES;
      • 查询表的结构: DESC 表名;
    3. U(Update): 修改
      1. 修改表名:

        ALTER TABLE 表名 RENAME TO 新表名;
      2. 修改表的字符集:

        ALTER TABLE 表名 CHARACTER SET 字符集名称;
      3. 添加一列:

        ALTER TABLE 表名 ADD 列名 数据类型
      4. 修改列名 类型:

        ALTER TABLE 表名 CHANGE 列名 新列名 新数据类型;

        只修改数据类型

        ALTER TALBE 表名 MODIFY 列名 新数据类型;
      5. 删除列:

        ALTER TABLE 表名 DROP 列名;
    4. D(Delete):删除
      • DROP TABLE 表名; 或者 DROP TABLE IF EXISTS 表名;

SQL概念及DDL语句的更多相关文章

  1. 常用SQL DDL语句

    常用SQL DDL语句 DDL-数据库定义语言:直接提交的.CREATE:用于创建数据库对象.DECLARE:除了是创建只在过程中使用的临时表外,DECLARE语句和CREATE语句非常相似.唯一可以 ...

  2. 九、dbms_ddl(提供了在PL/SQL块中执行DDL语句的方法)

    1.概述 作用:提供了在PL/SQL块中执行DDL语句的方法,并且也提供了一些DDL的特殊管理方法. 2.包的组成 1).alter_compile说明:用于重新编译过程.函数和包语法:dbms_dd ...

  3. MySQL-第二篇SQL语句基础(1)语句分类及DDL语句

    1.什么是SQL语句 SQL是Structed Query Language的缩写,即结构化查询语言.SQL是操作和检索数据库的标准语言,标准的SQL语句可以操作任何关系数据库. 2.标准的SQL语句 ...

  4. Oracle获取干净的建表DDL语句,不含其它存储、表空间、段属性

    早上一个同事资讯怎么获取到建表语句而且是不带存储那种SQL.Oracle自己提供了一个函数DBMS_METADATA.GET_DDL,但是获取到的建表语句含有存储.表空间.以及一些其他段的属性.如图: ...

  5. 数据库DDL语句书写规范

    数据库DDL语句书写规范 1.SQL语句编写说明编写SQL语句应遵循统一的规范,包括大小写.空格.换行.缩进等等,只有完全一样的SQL才能在数据库中共享,从而减少硬解析. 字段类型.长度:根据数据情况 ...

  6. Hibernate hbm2ddl.auto DDL语句 控制台输出的配置

    在开发中我们需要知道hbm2ddl.auto生成的SQL语句,来判断代码的正确性,现在记录配置的过程. Hibernate的DDL语句在控制台的输出配置: 一.在lib中确保只有下面的三个相关包:1) ...

  7. oracle使用dbms_metadata包取得所有对象DDL语句

    当我们想要查看某个表或者是表空间的DDL的时候,可以利用dbms_metadata.get_ddl这个包来查看. dbms_metadata包中的get_ddl函数详细参数 GET_DDL函数返回创建 ...

  8. 利用dbms_metadata.get_ddl查看DDL语句

    http://www.cnblogs.com/aocle/archive/2011/10/13/2209790.html 当我们想要查看某个表或者是表空间的DDL的时候,可以利用dbms_metada ...

  9. mysql DDL语句

    sql语言分为三个级别. 1.ddl 语句 ,数据定义语句,定义了数据库.表.索引等对象的定义.常用语句包含:create.drop.alter. 2.dml 语句 ,数据操纵语句,用于添加.删除.更 ...

随机推荐

  1. 【Python】Python figure显示的两种方式

    1. 两种方式: 终端输出图像新窗口输出图像 2. 终端输出命令: %matplotlib inline 新窗口输出命令: %matplotlib qt5 注意此两个语句是命令行输入,若在spyder ...

  2. 【LeetCode】091. Decode Ways

    题目: A message containing letters from A-Z is being encoded to numbers using the following mapping: ' ...

  3. codevs2189数字三角形w——最优性转化

    题目:http://codevs.cn/problem/2189/ 通过增加一维,将最优性转化为可行性. 代码如下: #include<iostream> #include<cstd ...

  4. POJ2349(求生成树中符合题意的边)

    Arctic Network Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 14977   Accepted: 4777 D ...

  5. 三层架构与MVC比较:

    三层架构与MVC比较: 1.两者不是同一概念 三层架构是一个分层式的软件体系架构设计,它可适用于任何一个项目. MVC是一个设计模式,它是根据项目的具体需求来决定是否适用于该项目. 那么架构跟设计模式 ...

  6. Docker入门(五):Swarms

    这个<Docker入门系列>文档,是根据Docker官网(https://docs.docker.com)的帮助文档大致翻译而成.主要是作为个人学习记录.有错误的地方,Robin欢迎大家指 ...

  7. Angular 2 ViewChild & ViewChildren

    一.ViewChild ViewChild 是属性装饰器,用来从模板视图中获取匹配的元素.视图查询在 ngAfterViewInit 钩子函数调用前完成,因此在 ngAfterViewInit 钩子函 ...

  8. Pointer 指针

    利用指针访问对象,指针指向一个对象,允许使用解引用符(操作符*)来访问对象 int ival = 42; int *p = &ival;//p存放变量ival的内存地址,p是指向变量ival的 ...

  9. 错误: 实例 "ahwater-linux-core" 执行所请求操作失败,实例处于错误状态。: 请稍后再试 [错误: Exceeded maximum number of retries. Exceeded max scheduling attempts 3 for instance 7c1609c9-9d0f-4836-85b3-cefd45f942a7. Last exception: [u

    错误: 实例 "ahwater-linux-core" 执行所请求操作失败,实例处于错误状态.: 请稍后再试 [错误: Exceeded maximum number of ret ...

  10. SynEdit(Delphi XE7)的安装和基本使用

    一.花絮 delphi自带的memo显示sql语句看的太累人了,今天决定美化一下.最起码要有“语法着色”.“显示行号”这2个功能. 意外发现了 SynEdit 控件. SynEdit是一个免费的文字编 ...