数据库系统原理之SQL(三)


1. SQL的组成

1. 数据查询
2. 数据定义
3. 数据操作
4. 数据控制

2. 数据定义语言

  1. CREATE创建数据库或数据库对象

    1. 创建数据库

      ~~~
      CREATE {DATABASE | SCHEMA} [IF NOT EXISTS] db_name [DEFAULT] CHARSET SET utf8 [DEFAULT] COLLATE utf8_general_ci
      ~~~
    2. 创建表

       ~~~
      #创建表并设置主键和索引
      CREATE TABLE table_name (id int not null AUTO_INCREMENT,name char(50) not null default "",age int null,PRIMARY KEY(id),INDEX index_age(age));
      ~~~
    3. 查看数据库

       ~~~
      #可以根据正则匹配或者where从句来获取想看到的数据库
      SHOW {DATABASES | SCHEMAS} [LIKE’pattern’ | WHERE expr]

  2. ALTER对数据库或数据库对象进行修改

    1. 修改数据库

      ALTER DATABASE db_name DEFAULT CHARACTER SET gb2312 DEFAULT COLLATE gb2312_chinese_ci;
    2. 更新表

      1. 在表中添加一个字段,并在原表的sex字段之后

         ALTER TABLE table_name
        ADD COLUMN city char(50) not null default "" after sex;
      2. 修改表中的列名或数据类型

      修改表table_name中的字段c_name为name,并设置字段类型

      ALTER TABLE table_name

      CHANGE COLUMN c_name name char(50) not null default "";

      ~~~

      1. 修改或删除指定列的默认值

        ALTER TABLE table_name
        ALTER COLUMN [drop default | set default "" ]
      2. 只修改指定列的数据类型,不会干涉它的列名

           #first 将此列设为表的第一列
        ALTER TABLE table_name
        MODIFY COLUMN name char(25) not null first;
      3. 删除表中多余的字段

        ALTER TABLE table_name
        DROP COLUMN name;
      4. 为表重新命名

        ALTER TABLE table_name
        RENAME TO back_table_name;
        RENAME TABLE table_name TO back_name;
  3. DROP删除数据库或数据库对象

    1. 删除数据库

      DROP{DATABASE|SCHEMA}[IF EXISTS]db_name
    2. 删除表

      DROP TABLE [IF EXISTS] table_name [,table_name2]
  4. 查看表

    SHOW [FULL] COLUMNS {FROM | IN} tbl_name[{FROM | IN} db_name]
    [LIKE’pattern’ | WHERE expr]
    {DESCRIBE | DESC} tbl_name [col_name | wild]

3. 数据操纵语言

  1. SELECT从表中或视图中检索数据(查)
  2. INSERT将数据插入插入到表或视图中(增)
  3. UPDATE修改表或视图中的数据(改)
  4. DELETE删除表或视图中的数据(删)

4. 数据控制语言

  1. GRANT授予权限
  2. REVOKE收回权限

5. 索引定义

​ 索引是提高数据文件访问效率的有效方法

  1. 弊端:
  • 索引是以文件的形式存储的,如果有大量的索引,索引文件可能比数据文件更快达到最大的文件尺寸;
  • 索引在提高查询速度的同时,会降低更新表的速度。
  1. 索引类型

    1. 普通索引(INDEX或KEY)
    2. 唯一性索引(UNIQUE)
    3. 主键(PRIMARY KEY)
  2. 创建索引(CREATE INDEX不能创建主键索引)

    #在table_name表上的column字段上创建唯一索引index_name,可设置长度和升序降序
    CREATE [UNIQUE] INDEX index_name ON table_name (column [(length)][ASC | DESC])
    #为表table_name添加索引index_name
    ALTER TABLE table_name ADD INDEX index_name(name);
  3. 查看索引

    SHOW {INDEX | INDEXES | KEYS} {FROM | IN} table_name [{FROM | IN} db_name] [WHERE expr]
  4. 删除索引

    DROP INDEX index_name ON table_name
    ALTER TABLE table_name DROP PRIMARY KEY,DROP INDEX index_name;

6. MySQL内置函数

函数 描述 示例
CURDATE() 返回当前日期 SELECT CURDATE()---- 2018-09-19
ABS(X) 返回X的绝对值 select ABS(-5) ---返回5
AVG(expression) 返回表达式的平均值 返回一个班年龄的平均值---SELECT AVG(age) from class
COUNT(expression) 返回记录数量 返回A表中的数据量---SELECT COUNT(*) from A
MAX(expression) 返回字段中的最大值 返回一个班中最大的年龄---SELECT MAX(age) from class
MIN(expression) 返回字段中的最小值 返回一个班中最小的年龄---SELECT MIN(age) from class
SUM(expression) 返回指定字段的总和 返回一个班的分数总和---SELECT SUM(fraction) from class

数据库系统原理之SQL(三)的更多相关文章

  1. 数据库系统原理之SQL(四)

    数据库系统原理之SQL(四) 1. 数据更新 插入数据 INSERT-VALUES语句 #插入多条数据 insert [into] table_name (column_name,...) value ...

  2. Atiti 数据库系统原理 与数据库方面的书籍 attilax总结 v3 .docx

    Atiti 数据库系统原理 与数据库方面的书籍 attilax总结 v3 .docx 1.1. 数据库的类型,网状,层次,树形数据库,kv数据库.oodb2 1.2. Er模型2 1.3. Sql2 ...

  3. php面试专题---Mysql索引原理及SQL优化

    php面试专题---Mysql索引原理及SQL优化 一.总结 一句话总结: 注意:只写精品 1.为表设置索引要付出代价 是什么? 存储空间:一是增加了数据库的存储空间 修改插入变动索引时间:二是在插入 ...

  4. 数据库系统原理——ER模型与关系模型

    原文链接: http://blog.csdn.net/haovip123/article/details/21614887 犹记得第一次看<数据库系统原理>时看天书的感觉,云里雾里:现在已 ...

  5. 基于Spark1.3.0的Spark sql三个核心部分

    基于Spark1.3.0的Spark sql三个核心部分: 1.可以架子啊各种结构化数据源(JSON,Hive,and Parquet) 2.可以让你通过SQL,saprk内部程序或者外部攻击,通过标 ...

  6. Linq to Sql : 三种事务处理方式

    原文:Linq to Sql : 三种事务处理方式 Linq to SQL支持三种事务处理模型:显式本地事务.显式可分发事务.隐式事务.(from  MSDN: 事务 (LINQ to SQL)).M ...

  7. JAVA-Unit01: 数据库原理 、 SQL(DDL、DML)

    Unit01: 数据库原理 . SQL(DDL.DML) SQL语句是不区分大小写的,但是行业里习惯将关键字与分关键字用大小写岔开以提高可读性. SELECT SYSDATE FROM dual DD ...

  8. WebSocket原理与实践(三)--解析数据帧

    WebSocket原理与实践(三)--解析数据帧 1-1 理解数据帧的含义:   在WebSocket协议中,数据是通过帧序列来传输的.为了数据安全原因,客户端必须掩码(mask)它发送到服务器的所有 ...

  9. 7.27实习培训日志-Oracle SQL(三)

    Oracle SQL(三) 视图 特性 简单视图 复杂视图 关联的表数量 1个 1个或多个 查询中包含函数 否 是 查询中包含分组数据 否 是 允许对视图进行DML操作 是 否 CREATE [OR ...

随机推荐

  1. python函数知识一 函数初始、定义与调用、返回值、参数和函数的好处+菜中菜

    第四章 函数 1.函数初识: def :关键字 -- 定义 函数名:和变量的定义方式一样 (): 用于参数传递,: 形参:函数的定义中()内的是形参 实参:调用的()内是实参 传参:调用时将实参传递给 ...

  2. SpringBoot | 第三十八章:基于RabbitMQ实现消息延迟队列方案

    前言 前段时间在编写通用的消息通知服务时,由于需要实现类似通知失败时,需要延后几分钟再次进行发送,进行多次尝试后,进入定时发送机制.此机制,在原先对接银联支付时,银联的异步通知也是类似的,在第一次通知 ...

  3. Python学习3——Python的简单推导

    列表推导是一种从其他列表创建列表的方式,类似于数学中的集合推导,列表推导的工作原理非常简单,类似于for循环.(以下代码均在IDLE实现) 最简单的列表推导: >>>[x*x for ...

  4. c实现生产者消费者问题。 windows下。

    #include <stdio.h>#include <windows.h> #define P(S) WaitForSingleObject(S,INFINITE)//定义W ...

  5. Nodejs监控Apple召回计划&邮件提醒

    最近,我的MacBook Pro 2015款13寸电池膨胀了 把笔记本平放在桌面,四个脚中的前两个无法落地,笔记本盖合上之后,屏幕上会印上键盘的纹路,也就是说,笔记本C面D面变形了,已经购买超过3年, ...

  6. [译]为任意网格计算tangent空间的基向量

    +BIT祝威+悄悄在此留下版了个权的信息说: [译]为任意网格计算tangent空间的基向量 Computing Tangent Space Basis Vectors for an Arbitrar ...

  7. STL 优先队列 用法

    今天做题用到了优先队列 对它的用法还不是很熟悉 现在整理一下. 需要的库 #include<queue> using namespace std; 不过我都用bits/stdc++.h.. ...

  8. Java常用命令及参数

    Java的基本指令参数 javac [-d 目录|-verbose] file java [-classpath(cp) dir] file jar -zcvf dir file javap [-pr ...

  9. sqlmap用法大全

    sqlmap参数详解: Usage: python sqlmap.py [options] Options(选项): -h, --help            Show basic help mes ...

  10. bootstrap datatable editor 扩展

    需求: a. 表单样式更改. b. 表单大小更改. 思路: a. 通过设置modal css更改样式和大小.缺点,全局性的更改. b. 更改bootstrap-editor,可以通过某种方式将参数传入 ...