SQL中的SELECT_简单查询语句总结
--以scott用户下的dept和emp表为例
--注意:如果scott用户不能使用,请使用system用户登录
--解锁scott用户
ALTER USER SCOTT ACCOUNT UNLOCK;
--重新设置密码 (identified 被识别的)
alter user scott identified by tiger;
--选择 所有字段 scott用户部门表
SELECT * FROM scott.dept;
--员工表
SELECT * FROM scott.emp;
--SELECT{*, column [alias],...}FROM table;
SELECT empno,ename,sal FROM scott.emp;
--SELECT语句中的算术表达式
SELECT empno,ename,sal,sal * 12 FROM scott.emp;
--运算符的优先级
SELECT empno,ename,sal,sal * 12 + 100 FROM scott.emp;
SELECT empno,ename,sal,sal * (12 + 100) FROM scott.emp;
--字符串的连接操作符 \\(相当于java的++)
--把两个字段的数据使用_连接起来
SELECT empno ||'_'|| ename FROM scott.emp;
/**
重点:NULL 空值
空值是指不可用,未分配的值
空值不等于零或空格
任意类型都可以支持空值
包括空值的任何算术表达式都等于空
*/
--查询scott用户的emp表的所有列
SELECT * FROM scott.emp;
--查询scott用户的emp表的所有列,条件为comm等于0
SELECT * FROM scott.emp WHERE comm = 0;
--查询scott用户的emp表的所有列,条件为comm等于空字符串
SELECT * FROM scott.emp WHERE comm = '';
--查询scott用户的emp表的所有列,条件为comm等于空
SELECT * FROM scott.emp WHERE comm = NULL;
SELECT * FROM scott.emp WHERE comm IS NULL;
SELECT * FROM scott.emp WHERE comm IS NOT NULL;
SELECT empno,ename,sal,comm,(sal + comm,sal) * 12 FROM scott.emp;
--nvl函数(Java的方法,传参数进去返回结果)
--nvl(第一个参数,第二个参数),如果第一个参数为null,则取第二个参数
SELECT empno,ename,sal,comm,NVL(sal + comm,sal) * 12 FROM scott.emp;
--定义字段的别名,注意,别名不支持使用单引号
SELECT empno,ename,sal,sal * 12 AS yearsal FROM scott.emp;
SELECT empno,ename,sal,sal * 12 yearsal FROM scott.emp;
SELECT empno,ename,sal,sal * 12 AS "yearsal" FROM scott.emp;
SELECT empno,ename,sal,sal * 12 "yearsal" FROM scott.emp;
--查询规定:empno叫做columnName列名,eID叫做columnLable列标签(自己定义的别名)
SELECT empno AS eID,ename,sal,sal * 12 AS yearsal FROM scott.emp;
--JDBC中 getInt(String columnLable) 如果有别名则是别名,如果没有别名则columnLable就是别名
--DISTINCT关键字明显的有区别的
--缺省情况下查询显示所有行,包括重复行
SELECT deptno FROM scott.emp;
--DISTINCT关键字去除重复数据
SELECT DISTINCT deptno FROM scott.emp;
--DISTINCT的作用范围是后面所有字段的组合
SELECT DISTINCT deptno,ename FROM scott.emp;
SELECT * FROM scott.emp;
SELECT DISTINCT deptno,job FROM scott.emp;
--为什么DISTINCT的作用范围是后面所有字段的组合
SELECT DISTINCT deptno,ename FROM scott.emp WHERE deptno = 30;
--DISTINCT deptno之后比如30只有一条记录,而30有6个ename,所以无法显示完整的数据
--where子句 限制筛选数据,必须跟在from之后
SELECT * FROM scott.emp WHERE deptno = 20 OR deptno = 30;
SELECT * FROM scott.emp WHERE deptno = 30 AND mgr = 7698;
--比较运算符
SELECT * FROM scott.emp WHERE sal >= 800 AND sal <= 1600;
--between and
SELECT * FROM scott.emp WHERE sal BETWEEN 800 AND 1600;
--in 包含,in执行的时候会拆分成一堆的or
SELECT * FROM scott.emp WHERE deptno = 20 OR deptno = 30;
SELECT * FROM scott.emp WHERE deptno IN(20,30);
--like模糊查询 区分大小写
--%匹配所有 _匹配一个字符
--查询所有以 "s" 开头的员工
SELECT * FROM scott.emp WHERE ename LIKE 'S%';
--查询所有以"s"结尾的员工
SELECT * FROM scott.emp WHERE ename LIKE '%S';
--查询名字中包含"S"的员工
SELECT * FROM scott.emp WHERE ename LIKE '%S%';
--查询名字中第二个字符是A的员工
SELECT * FROM scott.emp WHERE ename LIKE '_A%';
--优先级的规则 先and 再or
SELECT ename,job,sal
FROM scott.emp
WHERE job='PERSIDENT'
OR job='SALESMAN'
AND sal>1500;
SELECT ename,job,sal
FROM scott.emp
WHERE job='SALESMAN'
OR (job='PERSIDENT'
AND sal>1500);
--order by 以...排序
--desc descend 降序
--asc ascend 升序
--对结果集排序 order by asc(升序 默认) desc(降序)
--注意:order by只能出现在sql语句的最后一行
--按照薪水从低到高排序
SELECT * FROM scott.emp ORDER BY sal;
SELECT * FROM scott.emp ORDER BY sal asc;
SELECT * FROM scott.emp ORDER BY sal desc;
SQL中的SELECT_简单查询语句总结的更多相关文章
- linq to ef(相当于sql中in的用法)查询语句
select * from DoctorInfo doctor where doctor.HosDepartId in (select Id from HospitalDepartment hd wh ...
- 浅谈sql 、linq、lambda 查询语句的区别
浅谈sql .linq.lambda 查询语句的区别 LINQ的书写格式如下: from 临时变量 in 集合对象或数据库对象 where 条件表达式 [order by条件] select 临时变量 ...
- T-SQL简单查询语句(模糊查询)
T-SQL简单查询语句 简单查询: 1.最简单查询(查所有数据) select * from 表名: 注:* 代表所有列 select * from info 2.查询指定列 select code, ...
- oracle中简单查询语句的格式及执行顺序分析
一条简单的查询sql格式如下: SELECT ... FROM .... [WHERE ...] --过滤单行 [GROUP BY ... [HAVING ...]]--GROUP BY对前面wh ...
- SQL 中的多条件查询
在应用程序开发中,多条件查询是个经常遇到的情况,最简单最麻烦的方法是把所有的可能情况都考虑到,但是无疑是繁琐的,而且很容易漏掉可能的情形,下面是SQL语句实现多条件查询的情况 select * fro ...
- sql中的不常见查询
1.对于CROSS APPLY 和 OUTER APPLY 的应用: CROSS APPLY 类似于INNER JOIN 但是,可以规定对于满足条件的数据需要关联几行,应用场景: 每个零件把第一个工单 ...
- SQL Serever学习9——基础查询语句
SQL语言概述 SQL是结构化查询语言(Structure Query Language),1974年提出,1979年被IBM实现,SQL语言已经成为关系型数据库的标准语言. 包括: DDL数据定义语 ...
- T-SQL简单查询语句
简单查询: 1.最简单查询(查所有数据)select * from 表名: 注:* 代表所有列select * from info 2.查询指定列select code,name from info ...
- MySQL简单查询语句练习
数据查询语法(DQL) DQL就是数据查询语言,数据库执行DQL语句不会对数据进行改变,而是让数据库发送结果集给客户端. 语法: SELECT selection_list /*要查询的列名称*/ F ...
随机推荐
- skynet源码阅读<7>--死循环检测
在使用skynet开发时,你也许会碰到类似这样的警告:A message from [ :0100000f ] to [ :0100000a ] maybe in an endless loop (v ...
- 前端CSS规范整理
一.文件规范 1.文件均归档至约定的目录中. 具体要求通过豆瓣的CSS规范进行讲解: 所有的CSS分为两大类:通用类和业务类.通用的CSS文件,放在如下目录中: 基本样式库 /css/core 通用U ...
- 「NOIP2014」「LuoguP2296」 寻找道路
Description 在有向图 G 中,每条边的长度均为 1 ,现给定起点和终点,请你在图中找一条从起点到终点的路径,该路径满足以下条件: 路径上的所有点的出边所指向的点都直接或间接与终点连通. 在 ...
- 【CAIOJ 1178】 最长共同前缀长度
[题目链接] 点击打开链接 [算法] EXKMP [代码] #include<bits/stdc++.h> using namespace std; #define MAXL 100001 ...
- saltstack自动化运维快速入门
saltstack自动化运维快速入门 关于saltstack 这个软件是干啥的 我这里就不介绍了 只是简单的说下是干啥的 网上的说法是 它是func的强化版本+ puppet的精简版 关于puppet ...
- Spring MVC访问页面直接显示源码
转自:https://blog.csdn.net/u011781521/article/details/78751253
- ol 与ul 的区别
1 <!DOCTYPE html> <html> <body> <ul> <li>咖啡</li> <li>牛奶< ...
- (水题)洛谷 - P1036 - 选数
https://www.luogu.org/problemnew/show/P1036 $n$ 才20的数据量,我当时居然还在想怎么分组组合,直接 $2^{20}$ 暴力搞就行了. $x_i $太大了 ...
- Hexo瞎折腾系列(2) - 添加背景图片轮播
动态背景图片插件jquery-backstretch jquery-backstretch是一款简单的jQuery插件,可以用来设置动态的背景图片,以下是官方网站的介绍. A simple jQuer ...
- pika消息中间件模块
参考: http://www.rabbitmq.com/tutorials/tutorial-one-python.html http://www.rabbitmq.com/tutorials/tut ...