(四)基本的SELECT语句
目录
基本的查询结构
SELECT...,最简单的的select语句,代码如下所示:
SELECT 1;
运行结果如下所示:
SELECT ... FROM,SELECT 标识的意思是,选择哪些列, FROM 标识的意思是,从哪个表中选择。 SELECT * FROM ......;表示选择所有的列; SELECT A, B FROM ......;表示选择A,B两列; 具体实现如下所示。
SELECT 1 ,2
FROM DUAL; # DUAL意思是伪表,用来维持基本结构
运行结果如下所示:
SELECT * FROM employees;
运行结果如下所示:
SELECT department_id, location_id
FROM departments;
运行结果如下所示:
列的别名
主要作用就是重命名一个列,具体语法如下所示:
- 紧跟列名,用空格隔开
- 也可以在列名和别名之间加入关键字AS
- 别名可以使用双引号引起来,以便在别名中包含空格或特殊的字符并区分大小写。
- AS 可以省略
具体实现如下所示:
SELECT last_name AS "name", commission_pct "comm" # 可以省略双引号,最好不要使用单引号
FROM employees;
运行结果如下所示:
去除重复行
在SELECT语句中使用关键字DISTINCT去除重复行
具体实现如下所示:
SELECT DISTINCT department_id
FROM employees;
运行结果如下所示:
注:如果distinct后面接了多列数据,那就会对后面所有列名的组合进行去重 ,而且,如果两列表长度不一致,会报错。
SELECT DISTINCT department_id,salary
FROM employees;
运行结果如下所示:
空值参与运算
- 所有运算符或列值遇到null值,运算的结果都为null
- 在 MySQL 里面, 空值不等于空字符串。一个空字符串的长度是 0,而一个空值的长 度是空。而且,在 MySQL 里面,空值是占用空间的。
具体代码如下所示:
SELECT employee_id,salary,commission_pct,
12 * salary * (1 + commission_pct) "annual_sal"
FROM employees;
运行结果如下所示:
我们可以采用其他的方法来解决空值运算的问题,具体代码如下所示:
SELECT employee_id,salary "月工资", salary * (1 + IFNULL(commission_pct, 0)) * 12 "年工资",commission_pct
FROM employees;
运行结果如下所示:
着重号
作用:为了解决与保留字、数据库系统或常用方法冲突,而引入着重号。
具体代码如下所示:
SELECT * FROM ORDER; # 表中有一个数据库名字叫order,所以会报错
运行结果如下所示:
解决办法:
SELECT * FROM `ORDER`;
运行结果如下所示:
显示表结构
作用:能够显示表的详细信息
DESCRIBE employees; # DESC 也可以
运行结果如下所示:
Field:表示字段名称。 Type:表示字段类型,这里 barcode、goodsname 是文本型的,price 是整数类型的。 Null:表示该列是否可以存储NULL值。 Key:表示该列是否已编制索引。PRI表示该列是表主键的一部分;UNI表示该列是UNIQUE索引的一 部分;MUL表示在列中某个给定值允许出现多次。 Default:表示该列是否有默认值,如果有,那么值是多少。 Extra:表示可以获取的与给定列有关的附加信息,例如AUTO_INCREMENT等。
查询常数
作用:可以将常数添加到每一列数据上,具体代码如下所示:
SELECT 'jxust',employee_id, last_name
FROM employees;
运行结果如下所示:
过滤数据
作用:能够返回我们需要的,满足我们条件的一些信息,代码如下所示:
语法:SELECT 字段1,字段2 FROM 表名 WHERE 过滤条件
SELECT employee_id, last_name, job_id, department_id
FROM employees
WHERE department_id = 90 ;
运行结果如下所示:
注:在sqlyog里,大小写不敏感。
SELECT *
FROM employees
WHERE last_name = 'King' ; # 写成'king'也是一样的
运行结果如下所示:
相关文章
- 7000+字图文并茂解带你深入理解java锁升级的每个细节
- 全文手敲代码,教你用Java实现扫雷小游戏
- 4种方法教你如何查看java对象所占内存大小
- 手绘图解java类加载原理
- Java中的线程到底有哪些安全策略
- Java中观察者模式与委托,还在傻傻分不清
- 一图详解java-class类文件原理
- Java遇上SPL:架构优势和开发效率,一个不放过
- 长篇图解java反射机制及其应用场景
- [java并发编程]基于信号量semaphore实现限流器
- java并发编程-StampedLock高性能读写锁
- 【java并发编程】ReentrantLock 可重入读写锁
- 【java并发编程】Lock & Condition 协调同步生产消费
- Java synchronized对象级别与类级别的同步锁
- java并发编程JUC第十二篇:AtomicInteger原子整型
- java并发编程JUC第十一篇:如何在线程之间进行对等数据交换
- java并发编程JUC第十篇:CyclicBarrier线程同步
- java并发编程JUC第九篇:CountDownLatch线程同步
- java并发编程工具类JUC第八篇:ConcurrentHashMap
- java并发编程工具类JUC第七篇:BlockingDeque双端阻塞队列