SQL概念
SQL全称(Structured Query Language):结构化查询语句,是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询和管理关系型数据库。
其实就是定义了所有关系型数据库的规则。但是每一种数据库的sql语句操作方式存在不一样的地方,也把这种不一样的地方称为该数据库的'方言'
SQL通用语句
- SQL语句可以单行或多行书写,以分号结尾
- 可以使用空格和缩进来增强语句的可读性
- MySQL数据库的SQL 语句不区分大小写, 关键字建议大写
- 注释- 单行注释: -- 注释内容 (--后要加空格) 或 # 注释内容(mysql特有)
- 多行注释: /* 注释内容 */
 
SQL语句分类
- DDL(Data Definition Language): 数据定义语言- 用来定义数据库对象:数据库,表,列等。 关键字:create,drop, alter等。
 
- DML(Data Manipulation Language): 数据操作语言- 用来对数据库中的表进行增删改操作。 关键字:insert,delete,update等。
 
- DQL(Data Query Language): 数据查询语言- 用来查询数据库中表的记录(数据)。 关键字:select, where等
 
- DCL(Data Control Language): 数据控制语言- 用来定义数据库的访问控制权限和安全级别,及创建用户。关键字: grant, revoke等
 
DDL: 操作数据库、表
- 操作数据库:CRUD(增删改查) - C(Create): 创建 - 创建数据库: CREATE DATABASE 数据库名称; 
- 创建数据库,判断是否存在,不存在则创建:CREATE DATABASE IF NOT EXISTS 数据库名称; 
- 创建数据库并指定其字符集: CREATE DATABASE 数据库名称 CHARACTER SET 字符集; 
 示例:- CREATE DATABASE IF NOT EXISTS dbName CHARACTER SET gbk;
 
- R(Retrieve): 查询 - 查询所有数据库的名称: SHOW DATABASES;
 示例: 
- 查询某个数据库的创建语句: SHOW CREATE DATABASE 数据库名称;
 示例: 
 - 从上图可以看出,在查询数据库创建语句时,也可以看到数据库的字符集,所以通过该语句也可以看出数据库的字符集 
- 查询所有数据库的名称: 
- U(Update): 修改 - 修改数据库的字符集: ALTER DATABASE dbName CHARACTER SET 字符集名称;示例: 
 
- 修改数据库的字符集: 
- D(Delete): 删除 - 删除数据库: DROP DATABASE 数据库名称;
- 判断数据库存在,存在则删除: DROP DATABASE IF EXISTS 数据库名称;
 
- 删除数据库: 
- 使用数据库 - 只有使用了数据库,才能对数据库里面的表等进行操作。若没有使用某一个数据库,而直接对其表进行操作,这样会发生错误,SQL语句并不会执行。 - 查询当前正在使用的数据库名称: select database(); 示例:  
 - NULL代表了当前没有使用任何数据库, - 使用数据库: USE 数据库名称;
 
- 查询当前正在使用的数据库名称: select database(); 示例: 
 
- 操作表 - C(Create): 创建 - 语法: - CREATE TABLE tableName( 列名1 数据类型1, 列名2 数据类型2, .... 列名n 数据类型n, [添加约束...] );
- 注意:最后一行不用加逗号(,);加了就会报错 
- 数据库中常用的数据类型: - 整数类型: int, bigint 等
- 浮点数: float,double,decimal 浮点数可以指定精度 如decimal(11,2) 代表了该浮点数的长度为11位,小数位只保留2位
- 日期类型:- date: 只包含年月日 yyyy-MM-dd;
- datetime: 包含年月日时分秒 yyyy-MM-dd HH:mm:ss;
- timestamp: 时间戳类型 包含年月日时分秒 yyyy-MM-dd HH:mm:ss; 如果在插入数据时,不给时间戳类型赋值,或赋值为null,则默认使用当前的系统时间,来自动赋值。并且只要对该类型所在的行进行CUD(增删改)操作,这个类型的字段会自动更新成当前系统时间
 
- 字符串类型: 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 被复制的表名; 
 
- R(Retrieve): 查询 - 查询某个数据库中所有表名称: SHOW TABLES;
- 查询表的结构: DESC 表名;
 
- 查询某个数据库中所有表名称: 
- U(Update): 修改 - 修改表名: ALTER TABLE 表名 RENAME TO 新表名;
- 修改表的字符集: ALTER TABLE 表名 CHARACTER SET 字符集名称;
- 添加一列: ALTER TABLE 表名 ADD 列名 数据类型
- 修改列名 类型: ALTER TABLE 表名 CHANGE 列名 新列名 新数据类型;
 只修改数据类型ALTER TALBE 表名 MODIFY 列名 新数据类型;
- 删除列: ALTER TABLE 表名 DROP 列名;
 
- 修改表名: 
- D(Delete):删除 - DROP TABLE 表名;或者- DROP TABLE IF EXISTS 表名;
 
 
 
  
  
  
 
 
  
 