转到进阶查询

查看表的结构

desc  表名;

 desc student;

查看整张表的数据

select * from 表名; //查整张表很耗时间

select* from student;

查看表的一列,或几列

select 列名,列名 from 表名;

 select name,age from student;

字符串连接 ||

select 'a'||'b' from dual 

查询时过滤掉重复的行

select distinct 列名,列名 from 表名;

 select distinct name,age from student;

使用算数表达式

用字段名进行加减乘除的运算

select score+5,name from student ; // 给所有人的成绩加5分,并查看成绩和对应的人名

取别名

select age "年龄" from student;

 

用nvl处理null值

 select  nvl(age,0) from student;   //如果 age中有null值则把它改成0;

order by 

asc 正序 desc 倒序

按查询结果的第三列排序

SELECT * FROM student ORDER BY 3 DESC

多字段排序

SELECT * FROM student ORDER BY 2 DESC,3 ASC --数字可换成字段

连接字符串

连接字符串有||相当于 sqlserver中的+

SELECT '工号为'||FNumber||'的员工姓名为'||FName FROM T_Employee; 

题外在sql语言中字符串用‘’单引号

where 查询时的条件

select  age  from student where age>60;

使用 like 模糊查询

1、 可以使用一个或多个% 查询包含某个字符的字段。

select name from student where '%a%b%';

表示查找name中 包含  ....a....b.... 的字符。

2、_ 下划线 表示单个任意字符

select name from student where '_a_b_';

查询 name 有五个单词组成,并且第二位是a,第四位是b。

3、[] 查询出带有括号内的某一个字符

select name from student where '[abw]';

查询出的name字符带有a、b、w中的一个。

select age from student where '[0-9]';

包含 0到9中的任意一个数字。

4、[^] 找出的字段中不能包含括号里的字符

select name from student where '[^abd]';

name里不能含有 a 或者 b 或者 d。

in

相当于=加上or

SELECT *FROM supplier WHERE supplier_name = 'IBM' OR supplier_name = 'Hewlett Packard' OR supplier_name = 'Microsoft';

和这句话是相等的

SELECT * FROM supplier WHERE supplier_name in ( 'IBM', 'Hewlett Packard', 'Microsoft');

用in更加简练,直观。

exsits

???

查询 空 时用is null

select *  from score where student is null;

时间查询

select DEAL_TIME  from TABLE where DEAL_TIME >= to_date('2017-2-1','yyyy-mm-dd')  and DEAL_TIME <= to_date('2017-3-1','yyyy-mm-dd');
select DEAL_TIME  from TABLE where DEAL_TIME >= to_date('2017-2-1 23:59:59','yyyy-mm-dd hh24-mi-ss'); 
select DEAL_TIME from TABLE where  to_char(DEAL_TIME,'yyyy-mm-dd')>='2017-01-02'

 

限制返回行数

select * from T_BD_STAFF where rownum = 1     --rownum <=10

如果固定想查第二行

select * from (select rownum as id,emp.* from emp where  rownum<=50) where id=2

随机查询几行

DBMS_RANDOM.VALUE ()方法

SELECT 字段A, 字段B
FROM (SELECT *
FROM emp
ORDER BY DBMS_RANDOM.VALUE ())
WHERE ROWNUM <= 3

dual

????

select into

登录用户日志查询

select sid, serial#,
username, --连接用户名
program, --应用程序名
machine, --机器名
osuser, --操作系统用户
logon_time --登录时间
from v$session;

在 sqlpuls中 使用 ed 指令能打开编辑记事本,打开记事本后,保存-关闭。

使用 \ 能执行上一条数据

使用 a 命令追加上 sql的内容。

a  sql      --强调 a 后面一定要是两个空格 不然会和上条命令间无空格

查询统计大于1行的字段

select name from table group by name having count(name)>

(9)oracle 表的基本查询的更多相关文章

  1. Oracle表的常用查询实验(一)

    Oracle表的常用查询实验(一) 练习1.请查询表DEPT中所有部门的情况. select * from dept; 练习2.查询表DEPT中的部门号.部门名称两个字段的所有信息. select d ...

  2. Oracle表的基本查询

    Oracle 分页 1.rownum分页 Select * from emp; Select a1.*,rownum rn from (Select * from emp) a1; 2.显示rownu ...

  3. Oracle表空间状态查询、意义及修改方式

    查询表空间状态 select tablesapce_name,status from dba_tablespaces; 表空间的状态属性主要有在线(online),离线(offline),只读(rea ...

  4. ORACLE 表空间使用率查询

    SELECT A.TABLESPACE_NAME, A.BYTES / (1024 * 1024 * 1024 ) TOTAL, B.BYTES / (1024 * 1024 * 1024 ) USE ...

  5. 六分钟学会创建Oracle表空间的步骤

    经过长时间学习创建Oracle表空间,于是和大家分享一下,看完本文你肯定有不少收获,希望本文能教会你更多东西. 1.先查询空闲空间 select tablespace_name,file_id,blo ...

  6. oracle 表查询(2)

    使用逻辑操作符号 问题:查询工资高于500 或者是岗位为MANAGER 的雇员,同时还要满足他们的姓名首字母为大写的J? or job = 'MANAGER') and ename LIKE 'J%' ...

  7. oracle 表查询(1)

    oracle 表基本查询 介绍在我们讲解的过程中我们利用scott 用户存在的几张表(emp,dept)为大家演示如何使用select语句,select 语句在软件编程中非常有用,希望大家好好的掌握. ...

  8. Oracle单表的简单查询

    Oracle单表的简单查询 查看表结构 desc emp; 查询所有列 Select * from emp; 查找所以部门编号(查指定的列) select deptnofrom emp; 查找编号不同 ...

  9. Oracle多表的简单查询

    Oracle多表的简单查询 .多表查询 多表查询是指基于两个和两个以上的表或是视图的查询. 问题:显示雇员名,雇员工资及所在部门的名字[笛卡尔集]? select t.ename,t.sal,t1.d ...

随机推荐

  1. adb logcat 日志过滤

    方法 1.采用wpa_supplicant:s   *:v 排除wpa_supplicant标签 adb -s 01d32e89cb94d599 logcat -v time -s wpa_suppl ...

  2. javaWEB简单商城项目

    javaWEB简单商城项目(一) 项目中使用到了上一篇博文的分页框架,还有mybatis,重点是学习mybatis.现在有些小迷茫,不知道该干啥,唉,不想那么多了,学就对了 一.项目功能结构 1.功能 ...

  3. 使用node构建一个自己的服务器

    我们做本地服务器,经常会选择Apache.IIS或者Tomcat,当然这些最方便的算是Apache,几乎不需要配置,最多就是配置下端口,亦或者我们想不用localhost,改成其他也是可以的,只要去更 ...

  4. jenkins shell脚本构建项目--留

    1.echo `date` "doing  compling  . . . " if [ "$RELEASE" == "false" ]; ...

  5. 软工实践 - 第十七次作业 Alpha 冲刺 (8/10)

    队名:起床一起肝活队 组长博客:https://www.cnblogs.com/dawnduck/articles/10023469.html 作业博客:班级博客本次作业的链接 组员情况 组员1(队长 ...

  6. FOJ Problem 1016 无归之室

     Problem 1016 无归之室 Accept: 926    Submit: 7502Time Limit: 1000 mSec    Memory Limit : 32768 KB  Prob ...

  7. nyoj 题目 孪生素数问题

    孪生素数问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:3   描述 写一个程序,找出给出素数范围内的所有孪生素数的组数.一般来说,孪生素数就是指两个素数距离为2,近的不能再 ...

  8. 01、JAVA开发准备

    一.首先要认识几个名词: 1. JRE(Java Runtime Environment ,JAVA运行环境):它包含Java虚拟机(JVM,Java Virtual Machine)和Java程序所 ...

  9. 基于HTTP协议的轻量级开源简单队列服务:HTTPSQS[转]

    HTTPSQS(HTTP Simple Queue Service)是一款基于 HTTP GET/POST 协议的轻量级开源简单消息队列服务,使用 Tokyo Cabinet 的 B+Tree Key ...

  10. altium designer同一工程多个原理图如何快速查找同一网络标号

    方法一:如果只知道网络标号的名称,尚未找到任何一个,可以:Ctrl+F,输入网络标号名称,可按顺序逐个查看各个网络标号. 方法二:如果已经看到一个所要查找的网络标号,可以:按住Alt键不放,鼠标左键单 ...