SQL概念及DDL语句

Wesley13
• 阅读 622

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;
        示例: SQL概念及DDL语句
      • 查询某个数据库的创建语句: SHOW CREATE DATABASE 数据库名称;
        示例: SQL概念及DDL语句

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

    3. U(Update): 修改

      • 修改数据库的字符集: ALTER DATABASE dbName CHARACTER SET 字符集名称; 示例: SQL概念及DDL语句
    4. D(Delete): 删除

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

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

      • 查询当前正在使用的数据库名称: select database(); 示例: SQL概念及DDL语句

      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 表名;
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
待兔 待兔
6个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Easter79 Easter79
3年前
sql注入
反引号是个比较特别的字符,下面记录下怎么利用0x00SQL注入反引号可利用在分隔符及注释作用,不过使用范围只于表名、数据库名、字段名、起别名这些场景,下面具体说下1)表名payload:select\from\users\whereuser\_id1limit0,1;!(https://o
Wesley13 Wesley13
3年前
SQL的基本概念与通用语法
1)SQL:StructureQueryLanguage结构化查询语言(1)其实就是定义了操作所有关系型数据库的规则:比如:你可以查询mysql也可以查询oracle(2)每一种数据库操作的方式存在不一样的地方,叫做“方言”2)通用语法(1)SQL语句可以单行或
Stella981 Stella981
3年前
Python3:sqlalchemy对mysql数据库操作,非sql语句
Python3:sqlalchemy对mysql数据库操作,非sql语句python3authorlizmdatetime2018020110:00:00coding:utf8'''
Easter79 Easter79
3年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Stella981 Stella981
3年前
PostgreSQL死锁进程及慢查询处理
1、死锁进程查看:SELECTFROMpg_stat_activityWHEREdatname'数据库名称'andwaitingtrue;pid进程id。2、慢查询SQL:selectdatname,pid,usename,application_name,client_addr,client
Wesley13 Wesley13
3年前
mysql常用基本操作
MySQL数据库SQL(StructuredQueryLanguage)结构化查询语言常用基本操作: /\DDL(DataDefinitionLanguage)数据定义语言\/  创建数据库:  createdatabase'数据库名称'charsetutf8;  删除数据库:  dropdat
Stella981 Stella981
3年前
ELK学习笔记之ElasticSearch的索引详解
0x00ElasticSearch的索引和MySQL的索引方式对比Elasticsearch是通过Lucene的倒排索引技术实现比关系型数据库更快的过滤。特别是它对多条件的过滤支持非常好,比如年龄在18和30之间,性别为女性这样的组合查询。倒排索引很多地方都有介绍,但是其比关系型
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这