转到进阶查询

查看表的结构

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. BP神经网络的手写数字识别

    BP神经网络的手写数字识别 ANN 人工神经网络算法在实践中往往给人难以琢磨的印象,有句老话叫“出来混总是要还的”,大概是由于具有很强的非线性模拟和处理能力,因此作为代价上帝让它“黑盒”化了.作为一种 ...

  2. 《Cracking the Coding Interview》——第4章:树和图——题目6

    2014-03-19 04:16 题目:找出一棵二叉搜索树中的中序遍历后继节点,每个节点都有指针指向其父节点. 解法1:分两种情况:向下走时,先右后左:向上走时,先左后右.如果目标节点有右子树,就向右 ...

  3. 抓包工具 - Fiddler - (三)

    <转载自 miantest> 我们知道Fiddler是位于客户端和服务器之间的代理,它能够记录客户端和服务器之间的所有 HTTP请求,可以针对特定的HTTP请求,分析请求数据.设置断点.调 ...

  4. JavaScript中最常用的55个经典技巧,没事的时候看看,拓展解决问题的思路

    都转烂了,不过还是贴上来了.查的时候方便... test 1. oncontextmenu="window.event.returnValue=false" 将彻底屏蔽鼠标右键 & ...

  5. [shell]查找网段内可用IP地址

    #网段可用IP地址 #!/bin/sh ip= " ]; do .$ip -c |grep -q "ttl=" && echo "10.86.8 ...

  6. Python全栈工程师 (exercises)

    # 1:给定一个数,判断他是正数,负数,还是0 a = int(input("请输入一该个整数")) if a == 0: print(a, "是0") eli ...

  7. ESLint 代码检查规范

    目录 Airbnb Javascript Style Guide 引用 对象 数组 函数 箭头函数 类和构造器 模块 Iterators and Generators 变量 比较运算符 注释 空格 A ...

  8. FOJ Problem 1016 无归之室

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

  9. 【bzoj5055】膜法师 离散化+树状数组

    题目描述 给定一个序列$a$,求满足$i<j<k$且$a_i<a_j<a_k$的三元组$(i,j,k)$的个数. 输入 第一行1个数 n 第二行n个数 a_i 输出 一个数,表 ...

  10. [转]busybox中telnet 功能添加

    使用busybox制作的一个基本根文件系统如何添加telnetd服务呢? 下面把本人的添加过程列出来供大家分享,如有不同意见请不吝赐教! 1. 添加telnet的支持(busybox中配置) Netw ...