一、SQL概述
1、SQL背景知识
2、SQL语言排行
3、SQL分类
SQL语言在功能上主要分为如下3大类:
-
DDL(Data Definition Languages、数据定义语言),这些语句定义数据库、表、视图、索引等数据库对象,还可以用来创建、删除、修改数据库和数据表的结构
- 主要的语句关键字包括 CREATE 、 DROP 、 ALTER 等
-
DML(Data Manipulation Language、数据操作语言),用于添加、删除、更新和查询数据库记录
- 主要的语句关键字包括 INSERT 、 DELETE 、 UPDATE 、 SELECT 等
- SELECT是SQL语言的基础,最为重要
-
DCL(Data Control Language、数据控制语言),用于定义数据库、表、字段、用户的访问权限和安全级别
- 主要的语句关键字包括 GRANT 、 REVOKE 、 COMMIT 、 ROLLBACK 、 SAVEPOINT 等。
- 主要的语句关键字包括 GRANT 、 REVOKE 、 COMMIT 、 ROLLBACK 、 SAVEPOINT 等。
二、SQL语言的规则与规范
1、sql语言的基本规则
- SQL 可以写在一行或者多行。为了提高可读性,各子句分行写,必要时使用缩进
- 每条命令以 ; 或 \g 或 \G 结束
- 关键字不能被缩写也不能分行
2、sql的大小写规范
- MySQL 在 Windows 环境下是大小写不敏感的
- MySQL 在 Linux 环境下是大小写敏感的
数据库名、表名、变量名是严格区分大小写的
关键字、函数名、列名(或字段名)、列的别名(字段的别名) 是忽略大小写的 - 推荐采用统一的书写规范:
数据库名、表名、表别名、字段名、字段别名等都小写
SQL 关键字、函数名、绑定变量等都大写
3、注释
单行注释:#注释文字(MySQL特有的方式)
单行注释:-- 注释文字(–后面必须包含一个空格。)
多行注释:/* 注释文字 */
4、命名规则
数据库、表名不得超过30个字符,变量名限制为29个
数据库、表名必须只能包含 A–Z, a–z, 0–9, _共63个字符
数据库名、表名、字段名等对象名中间不要包含空格
待补充
5、数据导入指令
1) source 文件的全路径名 【注意:只能在命令行中执行,在图形化界面中执行会报错】
三、基本的SELECT语句
1、SELECT … FROM
SELECT 标识选择哪些列
FROM 标识从哪个表中选择
2、列的别名
SELECT last_name AS name, commission_pct comm
FROM employees;
3、去除重复行
默认情况下,查询会返回全部行,包括重复行
SELECT department_id
FROM employees;
在SELECT语句中使用关键字DISTINCT去除重复行
SELECT DISTINCT department_id
FROM employees;
【注意】DISTINCT 后面跟多个列名时,其实是对后面所有列名的组合进行去重,所以下面语句的执行结果比12条多,比107条少
SELECT DISTINCT department_id,salary
FROM employees;
4、空值参与运算
所有运算符或列值遇到null值,运算的结果都为 null
这里你一定要注意,在 MySQL 里面, 空值不等于空字符串。一个空字符串的长度是 0,而一个空值的长
度是空。而且,在 MySQL 里面,空值是占用空间的
5、着重号
我们需要保证表中的字段、表名等没有和保留字、数据库系统或常用方法名冲突。如果真的相同,请在SQL语句中使用一对``(着重号)引起来 例如 mysql> SELECT * FROM ORDER
;
四 、显示表结构
使用DESCRIBE 或 DESC 命令,表示表结构。
DESCRIBE employees;
或
DESC employees;
其中,各个字段的含义分别解释如下:
Field:表示字段名称。
Type:表示字段类型,这里 barcode、goodsname 是文本型的,price 是整数类型的。
Null:表示该列是否可以存储NULL值。
Key:表示该列是否已编制索引。PRI表示该列是表主键的一部分;UNI表示该列是UNIQUE索引的一
部分;MUL表示在列中某个给定值允许出现多次。
Default:表示该列是否有默认值,如果有,那么值是多少。
Extra:表示可以获取的与给定列有关的附加信息,例如AUTO_INCREMENT等。