如何从表中查询一个字端的数据

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子句的更多相关文章

  1. SQL语句之on子句过滤和where子句过滤区别

    1.测试数据: SQL> select * from dept;  DEPTNO DNAME          LOC ------ -------------- -------------   ...

  2. sql语句之where子句

    现在的登录都是把信息存在数据库,然后把输入的与数据库内容进行匹配,一样就登录成功,否则不成功.验证码是为了防止暴力破解,因为计算机能够自动匹配密码,但是不能识别图片上的字母,只有人能识别,所以匹配的速 ...

  3. 数据库性能调优——sql语句优化(转载及整理) —— 篇1

    一.问题的提出                    在应用系统开发初期,由于开发数据库数据比较少,对于查询SQL语句,复杂视图的的编写等体会不出SQL语句各种写法的性能优劣,但是如果将应用系统提交实 ...

  4. 数据库性能优化之SQL语句优化

    一.问题的提出 在应用系统开发初期,由于开发数据库数据比较少,对于查询SQL语句,复杂视图的编写等是体会不出SQL语句各种写法的性能优劣,但是如果将应用系统提交实际应用后,随着数据库中数据的增加,系统 ...

  5. SQL优化的四个方面,缓存,表结构,索引,SQL语句

    一,缓存 数据库属于 IO 密集型的应用程序,其主要职责就是数据的管理及存储工作.而我们知道,从内存中读取一个数据库的时间是微秒级别,而从一块普通硬盘上读取一个IO是在毫秒级别,二者相差3个数量级.所 ...

  6. 数据库 SQL语句优化

    温馨提示:本篇内容均来自网上,本人只做了稍微处理,未进行细致研究,仅当做以后不备之需,如若你喜欢可尽情转走. 一.问题的提出 在应用系统开发初期,由于开发数据库数据比较少,对于查询SQL语句,复杂视图 ...

  7. 优化的四个方面,缓存,表结构,索引,SQL语句

    一,缓存 数据库属于 IO 密集型的应用程序,其主要职责就是数据的管理及存储工作.而我们知道,从内存中读取一个数据库的时间是微秒级别,而从一块普通硬盘上读取一个IO是在毫秒级别,二者相差3个数量级.所 ...

  8. 数据库性能优化之SQL语句优化(上)

    一.问题的提出 在应用系统开发初期,由于开发数据库数据比较少,对于查询SQL语句,复杂视图的编写等体会不出SQL语句各种写法的性能优劣,但是如果将应用系统提交实际应用后,随着数据库中数据的增加,系统的 ...

  9. [转]数据库性能优化之SQL语句优化1

    一.问题的提出 在应用系统开发初期,由于开发数据库数据比较少,对于查询SQL语句,复杂视图的的编写等体会不出SQL语句各种写法的性能优劣,但是如果将应用系统提交实际应用后,随着数据库中数据的增加,系统 ...

随机推荐

  1. winform自动升级方案

    未涉及过winform升级,研究一阵,大致出来个不成熟的方案. 我的解决方案(判断升级,升级程序下载安装包的压缩包,解压,自动安装,重新启动程序). 1.首先根据服务器中软件版本号和本地软件版本号是否 ...

  2. Python 模块之wxpython 的应用

    第一个应用程序:“Hello World” 作为传统,我们首先将要写一个小的“Hello World”程序,下面是他的代码: #!/usr/bin/env python import wx app = ...

  3. C语言Socket-模拟远程CMD(客户端向服务器发送命令,服务器执行该命令)

    服务端(server) #include <stdio.h> #include <winsock2.h> #pragma comment(lib,"ws2_32.li ...

  4. CentOS 6(64-bit) + Nginx搭建静态文件服务器

    Nginx搭建静态文件服务器 使用命令打开Nginx配置文件: sudo vim /etc/nginx/conf.d/default.conf 将配置改为: server { ...... ..... ...

  5. 安装Centos7 随手记

    1.老笔记本安装Centos7 配置:酷睿I3  内存8G 2.原有系统Win7 将原来的硬盘空间,调整出60G 给Centos7 用. 3.安装Centos7 图形介面的,和windows安装过程类 ...

  6. OAuth 2.0 安全案例回顾

    原文:http://drops.wooyun.org/papers/598 0x00 背景 纵观账号互通发展史,可以发现OAuth比起其它协议(如OpenID)更流行的原因是,业务双方不仅要求账号本身 ...

  7. 全网最全的Windows下Anaconda2 / Anaconda3里Python语言实现定时发送微信消息给好友或群里(图文详解)

    不多说,直接上干货! 缘由: (1)最近看到情侣零点送祝福,感觉还是很浪漫的事情,相信有很多人熬夜为了给爱的人送上零点祝福,但是有时等着等着就睡着了或者时间并不是卡的那么准就有点强迫症了,这是也许程序 ...

  8. 详解C#委托和事件(二)

    一.当我们使用关键字delegate声明一个自定义委托类型时,实际上是声明了一个该名称的类类型,继承自抽象类System.MulticastDelegate,还包含实例方法Invoke.BeginIn ...

  9. lucene-01-简介

    1, 介绍 hadoop作者开发的 hdfs最开始作为netch的文件存储来使用的 2, 存储结构 lucene快的原因, 是因为添加数据的时候会对数据进行分词, 将分词后的词建立索引, 存储到索引库 ...

  10. MySQL复制以及调优

    一. 简介 MySQL自带复制方案,带来好处有: 数据备份. 负载均衡. 分布式数据. 概念介绍: 主机(master):被复制的数据库. 从机(slave):复制主机数据的数据库. 复制步骤: (1 ...