sql语句之from子句
如何从表中查询一个字端的数据
select 字段名 from 表名;
演示:从s_emp表中把月薪查询出来
select salary from s_emp ; (分号代表结束)

如何从表中查询多个字段的内容
select 字段名1 ,字段名2 from 表名;
演示:把s_emp表中的id first_name salary的数据查询出来
select ID , FIRST_NAME , SALARY from s_emp ;

如何查询表中所有字段对应的值
标准写法:一个一个列出来
简单写法:*号可以代替所有的字段名(但是这样不知道里面有哪些字段)
select * from 表名;
字段的数学运算(sql的数学运算)
+ - * /
演示:把s_emp 表中工资和工资减去100之后的工资显示出来
select salary , salary - 100 from s_emp ;

这样输出后,底层记录的salary是没有变化的
以salary+100算出一年的年薪:
select salary , 12*(salary + 100) from s_emp ;
一个月按照22天算,计算每天的薪水:
select salary , salary / 22 from s_emp ;(除数不会取整,和C不一样)

给字段起别名
select 字段名1 ,字段名2 别名 from 表名;
一个字段或者表达式只能有一个别名(也可以没有),别名会自动处理成大写
“别名”会原样显示所取的别名
演示:一年按照13个月计算 来计算每个人的年薪,列出每个月的月薪
select salary , salary*13 yearsal from s_emp ;

两个别名会报错:


sql中如何表达字符串
sql中的字符串使用单引号表达(C里使用双引号表达字符串字面值)
‘ ‘ ‘ ‘ ‘a’ ‘hello world’ 都是字符串
select first_name from s_emp ;也是字符串
如何拼接字符串
字符串拼接符:| |(只针对oracle,其他的可以查一下)
演示:
select first_name , last_name from s_emp ;

把名字拼接到一起:
select first_name || last_name name from s_emp ;

在姓名之间拼接一个单引号:
(在C语言中表达‘%’是%%,一个%就是占位符,%d;这里是一样的,用两个 ’ 表示单引号)
select first_name || ‘ ’’ ’ || last_name name from s_emp ;

在姓名之间拼接两个单引号:
select first_name || ‘ ‘’ ’ || ‘ ‘’ ’|| last_name name from s_emp ;
或者:
select first_name || ‘ ‘’ ‘’ ’ || last_name name from s_emp ;
空值(NULL值)的处理
空值(NULL值)和任何值做运算结果都是NULL
演示:一年按照12个月进行计算,考虑提成,总共的年薪是月薪乘以12,再加上提成(表中已有的的提成是COMMISSION_PCT)
salary*12+salary*12*(COMMISSION_PCT / 100)
或者:
salary*12*(1+COMMISSION_PCT / 100)

空值处理函数:nvl ( par1 , par2 )
可以处理任何类型的数据,但要求par1和par2的类型保持一致
这个函数,当par1为空时,返回par2的值;par1不为NULL时,返回par1的值
NULL要尽早处理
演示:
select salary , commission_pct , nvl ( salary*12*(1+commission_pct/100) , 0 ) from s_emp ;
是不行的,要尽早处理,不能等着运算完再处理

正确写法:
select salary , commission_pct , salary*12*(1+nvl ( commission_pct , 0 ) /100) from s_emp ;

演示:把每个员工的id first_name manager_id显示出来,如果manager_id是NULL,就把manager_id显示成-1
select id, first_name, manager_id, nvl(manager_id, -1)

数据的排重 distinct(封装的算法我们不用了解)
dstinct会把所有重复的数据剔除
联合排重(多字段排重,要两个字段都相同的才会剔除)
演示:
select salary from s_emp ; 查出所有薪水

select distinct salary from s_emp ; 把重复的剔除


select distinct title , salary from s_emp ;联合排重

sql语句之from子句的更多相关文章
- SQL语句之on子句过滤和where子句过滤区别
1.测试数据: SQL> select * from dept; DEPTNO DNAME LOC ------ -------------- ------------- ...
- sql语句之where子句
现在的登录都是把信息存在数据库,然后把输入的与数据库内容进行匹配,一样就登录成功,否则不成功.验证码是为了防止暴力破解,因为计算机能够自动匹配密码,但是不能识别图片上的字母,只有人能识别,所以匹配的速 ...
- 数据库性能调优——sql语句优化(转载及整理) —— 篇1
一.问题的提出 在应用系统开发初期,由于开发数据库数据比较少,对于查询SQL语句,复杂视图的的编写等体会不出SQL语句各种写法的性能优劣,但是如果将应用系统提交实 ...
- 数据库性能优化之SQL语句优化
一.问题的提出 在应用系统开发初期,由于开发数据库数据比较少,对于查询SQL语句,复杂视图的编写等是体会不出SQL语句各种写法的性能优劣,但是如果将应用系统提交实际应用后,随着数据库中数据的增加,系统 ...
- SQL优化的四个方面,缓存,表结构,索引,SQL语句
一,缓存 数据库属于 IO 密集型的应用程序,其主要职责就是数据的管理及存储工作.而我们知道,从内存中读取一个数据库的时间是微秒级别,而从一块普通硬盘上读取一个IO是在毫秒级别,二者相差3个数量级.所 ...
- 数据库 SQL语句优化
温馨提示:本篇内容均来自网上,本人只做了稍微处理,未进行细致研究,仅当做以后不备之需,如若你喜欢可尽情转走. 一.问题的提出 在应用系统开发初期,由于开发数据库数据比较少,对于查询SQL语句,复杂视图 ...
- 优化的四个方面,缓存,表结构,索引,SQL语句
一,缓存 数据库属于 IO 密集型的应用程序,其主要职责就是数据的管理及存储工作.而我们知道,从内存中读取一个数据库的时间是微秒级别,而从一块普通硬盘上读取一个IO是在毫秒级别,二者相差3个数量级.所 ...
- 数据库性能优化之SQL语句优化(上)
一.问题的提出 在应用系统开发初期,由于开发数据库数据比较少,对于查询SQL语句,复杂视图的编写等体会不出SQL语句各种写法的性能优劣,但是如果将应用系统提交实际应用后,随着数据库中数据的增加,系统的 ...
- [转]数据库性能优化之SQL语句优化1
一.问题的提出 在应用系统开发初期,由于开发数据库数据比较少,对于查询SQL语句,复杂视图的的编写等体会不出SQL语句各种写法的性能优劣,但是如果将应用系统提交实际应用后,随着数据库中数据的增加,系统 ...
随机推荐
- [leetcode.com]算法题目 - Symmetric Tree
Given a binary tree, check whether it is a mirror of itself (ie, symmetric around its center). For e ...
- 阻止事件冒泡,阻止默认事件,event.stopPropagation()和event.preventDefault(),return false的区别
1.event.stopPropagation()方法 这是阻止事件的冒泡方法,不让事件向documen上蔓延,但是默认事件任然会执行,当你掉用这个方法的时候,如果点击一个连接,这个连接仍然会被打开, ...
- Eleasticsearch启动失败问题解决
问题: [root@dnode1 bin]# ./elasticsearch -d [root@dnode1 bin]# Exception in thread "main" ja ...
- WebDriver高级应用实例(7)
7.1在测试中断言失败的步骤进行屏幕截图 目的:在测试过程中,在断言语句执行失败时,对当前的浏览器进行截屏,并在磁盘上新建一个yyyy-mm-dd格式的目录,并在断言失败时新建一个已hh-mm-ss格 ...
- dubbo管控台安装
1. jdk安装 # cp installpkgs/jdk-7u67-linux-x64_tar_gz /usr/local # tar -zxf jdk-7u67-linux-x64_tar_g ...
- Django Admin实现三级联动(省市区)
通过自定义Admin的模板文件实现省市区的三级联动.要求创建记录时,根据省>市>区的顺序选择依次显示对应数据. 修改记录时默认显示已存在的数据. Model class Member(mo ...
- logstash安装与logstash-input-jdbc插件使用
ElasticSearch的索引可以手动添加索引的,就是类似下面这样添加的 PUT /movies/movie/1 { "title": "The Godfather&q ...
- Python做int()强制类型转换的时候,小数是如何取舍的?
白月黑羽今天给大家分享一个冷知识:) int()强制类型转换小数是如何取舍的? 使用 int() 将小数转换为整数,小数取整会采用比较暴力的截断方式,即小数点后面的会被强制舍去,向下取整. 例如:5. ...
- 《Netty权威指南》(一)走进 Java NIO
目录 1.1 I/O 基础入门 1.1.1 Linux 网络 I/O 模型 1.1.2 I/O 多路复用技术 2. Java 的 I/O 演进 1.1 I/O 基础入门 Java1.4 之前的早期 ...
- ansible 角色登陆
用ansible 来管理远程的主机,最大的好处是方便,ansible不用在远程的主机上安装ansible的客户端,ansible只要能通过ssh连接上远程主机就 能对它进行管理.也就是说ansible ...