Oracle查询

函数:

1、基本函数  INICAP:把首字母转换为大写
    SELECT INICAP(NAME) FROM DUAL
  CONCAT:连接字符串
    SELECT CONCAT(NAME, AGE) FROM DAUL
  ROUND:四舍五入提成整数
    SELECT ROUND(WEIGHT) FROM DUAL2、特有函数DECODE  DECODE函数,是ORACLE公司的SQL软件ORACLE PL/SQL所提供的特有函数计算方式
  DECODE(QTY, 0, 1, QTY)
  如果QTY等于0就返回1,如果不等于0就返回QTY3、统计函数  SUM:计算字段的总和
  AVG:计算字段的平均值
  MIN:查找字段最小值
  MAX:查找字段最大值
  COUNT:计算字段中的值的数目
  DISTINCT:计算行中的不重复值
  NVL(字段,0):如果查询字段为NULL则返回0分组4、统计函数  GROUP BY:分组统计查询
    SELECT COLUMN,FUNCTION(COLUMN) FROM TABLE GROUP BY COLUMN
  HAVING:只能应用在GROUP BY后面
  SELECT JOB,SUM(SAL) FROM DUAL GROUP BY JOB HAVING SUM(SAL) > 10005、DUAL表  DUAL表示一个1行1列的表,不用向DUAL表中执行INSERT、DELETE、TRUNCATE6、ROWNUM伪列  Oracle没有类似SQL Service中的TOP关键字来获取表中的前几条记录,但是可以使用ROWNUM伪列
    SELECT ROWNUM,NAME,JOB FROM DUAL WHERE ROWNUM<=10
ROWNUM和ROWID最大的不同在于ROWID是物理存在的,ROWNUM是动态的,先查到结果集再加上去的一个列,因此必须先有结果集ROWID伪列ROWID是一种数据类型,它使用基于64位编码的18个字符来唯一标识一条记录的物理位置的一个ID,有点类似于主键,不过与主键的本质区别是ROWID一般情况下是按照递增的顺序排列
7、ROWID可以查询,但是不是存储在表中,因此不支持插入、更新、删除
  ROWID通过ROWIDTOCHAR转换为字符串进行显示
  SELECT ROWIDTOCHAR(ROWID) FROM DAUL

多表连接:

1、Oracle特有的连接查询SELECT TB1,TB2 FROM TB1,TB2 WHERE TB1.COLUMN=TB2.COLUMN
在一个表中指定外键,在另外一个表中指定与其关联的主键2、内连接Oracle写法:
SELECT TB1,TB2 FROM TB1,TB2 WHERE TB1.COLUMN=TB2.COLUMN
标准写法:
SELECT TB1,TB2 FROM TB1 INNER JOIN TB2 ON TB1.COLUMN=TB2.COLUMN3、外连接左连接(Oracle写法):
  SELECT TB1.COLUMN,TB2.COLUMN FROM TB1,TB2 WHERE TB1.COLUMN=TB2.COLUMN(+)
右连接 (Oracle写法):  
  SELECT TB1.COLUMN,TB2.COLUMN FROM TB1,TB2 WHERE TB1.COLUMN(+)=TB2.COLUMN4、交叉连接交叉连接是指用A表的记录与B表中的记录行数相乘得到的笛卡尔积,例如A表有15条记录,B表有6条记录,那么查找出来的就是15*6=90条记录
Oracle写法:
  SELECT TB1.COLUMN TB2.COLUMN FROM TB1,TB2
标准写法:
   SELECT TB1.COLUMN TB2.COLUMN FROM TB1 CROSS JOIN TB25、自然连接两张表中有相同名字和数据类型的列,那么可以使用自然连接来自动匹配数据类型和列名
自然连接使用NATURAL JOIN
   SELECT TB1.COLUMN TB2.COLUMN FROM TB1 NATURAL JOIN TB2
时间: 2024-10-01 12:41:12

Oracle查询的相关文章

oracle查询转换_inlist转换

oracle的optimizer会对一些sql语句进行查询转换,比如: 合并视图 子查询非嵌套化 inlist转换 下面讲讲遇到的in list转化优化的案例: create table test( col1 varchar2(12) col2 number ext varchar2(4000) ); create index test_ind on test(user_id, col2); create sequence seq_test cache 200; 第一步:准备一些测试数据(10个

oracle查询转换_view merge

oracle对于子查询的支持做的很好,oracle optimizer会对inline view进行query transfomation,即视图合并,不过也经常带来意想不到的问题.下面是一个inline view的merge的例子: 1, 创建临时表 1 create table test1 as select * from dba_objects; 2 create table test2 as select * from dba_objects; 2, 以下查询语句 select * fr

Oracle查询总结

-------------------------------多表查询-------------------------------------- --笛卡尔积查询. select * from emp,dept;--结果为64条,emp表有14条,dept表有4条 --别名查询 --改变查询后的结果显示的列名,在字段后面写要显示的列名(注意一定要用双引号括起来,oracle查询中之后这里用到双引号!) select ename "name" ,loc "地点" f

45个非常有用的 Oracle 查询语句小结

 这里我们介绍的是 40+ 个非常有用的 Oracle 查询语句,主要涵盖了日期操作,获取服务器信息,获取执行状态,计算数据库大小等等方面的查询.这些是所有 Oracle 开发者都必备的技能,所以快快收藏吧. 原文地址:http://www.jbxue.com/db/19890.html 日期/时间 相关查询 1.获取当前月份的第一天 运行这个命令能快速返回当前月份的第一天.你可以用任何的日期值替换 "SYSDATE"来指定查询的日期. 复制代码代码如下: SELECT TRUNC

Oracle查询被锁的表及进程的方法

Oracle查询可以有多种方法,下面为您介绍的是如何Oracle查询被锁的表及Oracle查询连接的进程的方法,希望对您能够有所帮助. 一.查看被锁的表 select p.spid,a.serial#, c.object_name,b.session_id,b.oracle_username,b.os_user_name from v$process p,v$session a, v$locked_object b,all_objects c where p.addr=a.paddr and a

45 个非常有用的 Oracle 查询语句

这里我们介绍的是 40+ 个非常有用的 Oracle 查询语句,主要涵盖了日期操作,获取服务器信息,获取执行状态,计算数据库大小等等方面的查询.这些是所有 Oracle 开发者都必备的技能,所以快快收藏吧! 日期/时间 相关查询 获取当前月份的第一天 运行这个命令能快速返回当前月份的第一天.你可以用任何的日期值替换 "SYSDATE"来指定查询的日期. ? 1 2 SELECT TRUNC (SYSDATE, 'MONTH') "First day of current mo

转,Oracle中关于处理小数点位数的几个函数,取小数位数,Oracle查询函数

关于处理小数点位数的几个oracle函数() 1. 取四舍五入的几位小数 select round(1.2345, 3) from dual; 结果:1.235 2. 保留两位小数,只舍 select trunc(1.2345, 2) from dual; 结果:1.23 select trunc(1.2399, 2) from dual; 结果:1.23 3.取整数 返回大于或等于x的最大整数: SQL> select ceil(23.33) from dual; 结果: 24 返回等于或小于

ORACLE查询并删除重复记录

查询及删除重复记录的SQL语句 1.查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断select * from peoplewhere peopleId in (select   peopleId from   people group by   peopleId having count(peopleId) > 1) 2.删除表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断,只留有rowid最小的记录delete from people where

ORACLE查询数据库的锁表情况

  查询数据库的锁表情况语句如下: SELECT p.spid,a.serial#, c.object_name,b.session_id,b.oracle_username,b.os_user_name FROM v$process p,v$session a, v$locked_object b,all_objects c WHERE p.addr=a.paddr AND a.process=b.process AND c.object_id=b.object_id 如果表因为某些情况出现死

oracle查询所有用户表的表名、主键名称、索引、外键等

1.查找表的所有索引(包括索引名,类型,构成列): select t.*,i.index_type from user_ind_columns t,user_indexes i where t.index_name = i.index_name and t.table_name = i.table_name and t.table_name = 要查询的表 2.查找表的主键(包括名称,构成列): select cu.* from user_cons_columns cu, user_constr