@[toc]
基本的SELECT语句
- SELECT...
SELECT 2*2;
SELECT 9/2; #没有任何子句
- SELECT ... FROM
SELECT 标识选择哪些列
FROM 标识从哪个表中选择
- 选择全部列和查询某列
# *:表中所有的字段(或列)
SELECT * FROM countries;
# 查询某列
SELECT country_id
FROM countries;
注意:一般情况下,除非需要使用表中所有的字段数据,最好不要使用通配符‘ ’。使用通配符虽然可以节 省输入查询语句的时间,但是获取不需要的列数据通常会降低查询和所使用的应用程序的效率。通 配符的优势是,当不知道所需要的列的名称时,可以通过它获取它们。 在生产环境下,不推荐你直接使用 SELECT 进行查询。
列的别名
- 重命名一个列
- 便于计算
- 紧跟列名,也可以在列名和别名之间加入关键字AS,别名使用双引号,以便在别名中包含空格或特殊的字符并区分大小写。
- AS 可以省略
- 建议别名简短,见名知意
- 举例
SELECT country_id,country_name
FROM countries;
# 列的别名:
SELECT country_id emp_id,country_name AS emp_name,region_id "第三列"
FROM countries;
注意:第三种方式加双引号是可以去掉的,但是某些情况不可以,比如当名字中间有空格的时候
# 列的别名:(这么写就会报错)
SELECT country_id emp_id,country_name AS emp_name,region_id 第 三列
FROM countries;
去除重复行
使用场景举例:比如某表里面有很多员工,员工对应了职位,把所有职位去重,就看见了总共有那些职位
#未去重
SELECT department_id
FROM employees;
#去重
SELECT DISTINCT department_id
FROM employees;
- DISTINCT 需要放到所有列名的前面,如果写成 SELECT salary, DISTINCT department_id FROM employees 会报错。
错误举例:
第一种:去重部分
SELECT salaru,DISTINCT department_id
FROM employees;
解释:会报错,前面不去重后面去重,没法实现
第二种:整体去重
SELECT DISTINCT department_id,salaru
FROM employees;
解释:不会报错,但是毫无意义,查重是去除的是两个列的元素整体来看不同的
空值(null)
- null不等同于0、‘ ’、‘null’
- null参与运算,结果也一定为null
举例:这里部分员工的年工资变成了null,因为null不等于,只要参与了运算,结果就为null
着重号
命名规则有说到:必须保证你的字段没有和保留字、数据库系统或常用方法冲突。如果坚持使用,请在SQL语句中使 用`(着重号)引起来
解释:这里的order表和关键字重名了,所以需要用着重号,不然会报错
查询常数
SELECT 查询还可以对常数进行查询。就是在 SELECT 查询结果中增加一列固定的常数列。这列的 取值是我们指定的,而不是从数据表中动态取出的。 你可能会问为什么我们还要对常数进行查询呢? SQL 中的 SELECT 语法的确提供了这个功能,一般来说我们只从一个表中查询数据,通常不需要增加一个 固定的常数列,但如果我们想整合不同的数据源,用常数列作为这个表的标记,就需要查询常数。 比如说,我们想对 employees 数据表中的员工姓名进行查询,同时增加一列字段员工所属公司 ,这个 字段固定值为“华为员工”,可以这样写:
SELECT '华为员工' as '员工所属公司', last_name FROM employees;
显示表结构
- 使用DESCRIBE 或 DESC 命令,表示表结构
- 这里用命令行演示不用navicat
- Field:表示字段名称。
- Type:表示字段类型,这里 barcode、goodsname 是文本型的,price 是整数类型的。
- Null:表示该列是否可以存储NULL值。
- Key:表示该列是否已编制索引。PRI表示该列是表主键的一部分;UNI表示该列是UNIQUE索引的一 部分;MUL表示在列中某个给定值允许出现多次。
- Default:表示该列是否有默认值,如果有,那么值是多少。
- Extra:表示可以获取的与给定列有关的附加信息,例如AUTO_INCREMENT等。
过滤数据
使用场景:比如返回某公司员工工资一栏达到5000以上的人员、某企业年收入过百万的部门等等筛选
语法:
SELECT 字段1,字段2
FROM 表名
WHERE 过滤条件
举例:找出下列表种salary大于5000的员工姓名
代码:
SELECT first_name '姓名',salary '工资'
FROM employees
WHERE salary >'5000';
注意:WHERE必须放在FROM后面