转到进阶查询

查看表的结构

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. B树、B-树、B+树、B*树 红黑树

    转载自:http://blog.csdn.net/quitepig/article/details/8041308 B树 即二叉搜索树: 1.所有非叶子结点至多拥有两个儿子(Left和Right): ...

  2. PhpStorm 格式化中花括号缩进方式

    格式化前: function func() { return ; } 格式化后: function func() { return ; } 在PhpStorm中的配置:File -> Setti ...

  3. Virtual box 虚拟机 不可使用的一种解决方法

    在win7下开着一个ubuntu虚拟机,写了好几小时代码,然后饿了,去吃点东西 回来发现,电脑由于win7 自动更新已经重启 ubuntu下的代码我已经走开时保存过了,所以不怎么担心 但是打开virt ...

  4. Limeng:Individual Project: Word frequency program -BUAA Advanced Software Engineering

    11061190-李孟 Implement a console application to tally the frequency of words under a directory (2 mod ...

  5. jsp处理

    jsp处理步骤: 浏览器发送一个HTTP请求给服务器. Web服务器识别出这是一个对JSP网页的请求,并且将该请求传递给JSP引擎.通过使用URL或者.jsp文件来完成. JSP引擎从磁盘中载入JSP ...

  6. js动态生成下拉列表

    经常需要用到js动态生成下拉列表的功能,记录下来备用. 示例需求:通过ajax请求,从后台获取用户姓名列表,并添加到下拉列表中.js代码如下: function getNameList(){ //如果 ...

  7. java值转递?引用传递?

    值传递是传递的是原值的副本,引用传递传递的是原值. 在Java中,如果是基本数据类型,传递的是该参数字面量值的拷贝.如果是引用数据类型,传递的是该参数所引用对象在堆中地址的拷贝. swap(int a ...

  8. ZooKeeper客户端 zkCli.sh 节点的配额设置

    首先使用 zkCli.sh 连接上ZooKeeper服务器 配额设置命令格式如下: setquota -n|-b val path -n:val设置子节点个数 -b:val设置节点的数据长度 如果我们 ...

  9. 【bzoj4010】[HNOI2015]菜肴制作 拓扑排序+堆

    题目描述 给你一张有向图,问:编号-位置序(即每个编号的位置对应的序列)最小(例如1优先出现在前面,1位置相同的2优先出现在前面,以此类推)的拓扑序是什么? 输入 第一行是一个正整数D,表示数据组数. ...

  10. DataBase -- Count & Group by

    SQL Count()函数: SQL COUNT(column_name)语法:COUNT(column_name)函数返回指定列的值得数目(NULL不计入) select count(column_ ...