oracle数据库条件判断的查询语句怎么写

oracle数据库条件判断的查询语句怎么写,第1张

建表,测试数据

create table test

(收款标志 int)

insert into test values (1);

insert into test values (1);

insert into test values (1);

commit;

执行:

select case

         when acnt = bcnt then

          '未收款'

         when acnt = dcnt then

          '已收款'

         when ccnt <> 0 then

          '部分收款'

       end 收款状态

  from (select count() cnt from test) a,

       (select count() cnt from test where 收款标志 = 1) b,

       (select count() cnt from test where 收款标志 = 2) c,

       (select count() cnt from test where 收款标志 = 3) d

结果:

然后你自己换点其他数据测试一下吧,思路就这么个思路了。

(1)sys那张表:查询dba系统权限视图,里面主要是用户,和这个用户拥有什么系统权限。

(2)tab那张表:dba表权限视图,比如A用户可以在B用户某张表里面查询,插入等。

(3)role那张表:dba角色权限视图,某个用户被授予了什么角色。比如A用户拥有DBA橘色权限等。

(4)users,dba用户视图,这里有所有用户的信息,比如用户名,创建时间,是否锁定等等。

(5)user$,user的基础视图,一般比较少用。

(6)dblink那张表:dblink视图,显示该数据库所有的dblink内容(dblink表示可连接数据库)。

(7)link$,上面那张dblink那张表的基础表,这里一般显示的是可以连接的数据库的表。

(8)dba_profiles:用户默认表,查询数据库中存在哪些profile,比如连续输入三次错误密码用户就锁定,这个就是一个profile。

(9)实例动态视图

1) 可以通过sql语句处理

select Sno,Sname,

CASE WHEN Grade>90 THEN '优秀'

WHEN Grade>80THEN '良好'

ELSE ’显示错误’END

,Class,Ssex,Sage,Grade

from lixiaoka

顺便说一下楼主分等级的思路有些错误,应该是两边都做判断。比如说良好的应该是80~90之间的而不是笼统的大于80

2)在sql语句中直接获取分数,在程序中作处理

如果数据量过多时,建议不要采用第一种方法,因为查询速度会降低

这里涉及到两个系统视图的应用dba_tab_cols和user_tab_cols;

dba_tab_cols包含所有用户下表字段信息;user_tab_cols包含当前用户下表信息;使用tba_tab_clos查询表字段类型需要指定owner(用户)

上述两个表中,table_name,column_name,data_type就可以满足需要查询表字段类型了,具体类型对应其他字段还有另外定义,比如varchar2,date,number还对应在data_length字段有值,说明类型其长度

user_tab_columns和user_tab_cols都可以满足问题要求,但是两张视图还是有区别的,主要是包含字段的区别等,具体区别可以度娘哈,这里就不赘述。

空间是数据库中最大的逻辑单位与存储空间单位 数据库系统通过表空间为数据库对象分配空间 表空间在物理上体现为磁盘数据文件 每一个表空间由一个或多个数据文件组成 一个数据文件只可与一个表空间相联系 这是逻辑与物理的统一 了解表空间和数据文件的的属性及使用率 是数据库管理员的一项重要职责 在本文中笔者将以oracle为例 详细介绍查询Oracle数据库表空间信息和数据文件信息的方法 希望能帮助大家更深入了解表空间的知识和应用

一 如何查看Oracle数据库中表空间信息的方法

从Oracle数据库中工具入手

使用oracle enterprise manager console工具 这是oracle的客户端工具 当安装oracle服务器或客户端时会自动安装此工具 在windows *** 作系统上完成oracle安装后 通过下面的方法登录该工具 开始菜单——程序——Oracle OraHome ——Enterprise Manager Console(单击)——oracle enterprise manager console登录——选择 独立启动 单选框—— 确定 —— oracle enterprise manager console 独立 ——选择要登录的 实例名 ——d出 数据库连接信息 ——输入 用户名/口令 (一般使用sys用户) 连接身份 选择选择SYSDBA—— 确定 这时已经成功登录该工具 选择 存储 ——表空间 会看到如下的界面 该界面显示了表空间名称 表空间类型 区管理类型 以 兆 为单位的表空间大小 已使用的表空间大小及表空间利用率

从Oracle数据库中命令方法入手

通过查询数据库系统中的数据字典表(data dictionary tables)获取表空间的相关信息 首先使用客户端工具连接到数据库 这些工具可以是SQLPLUS字符工具 TOAD PL/SQL等 连接到数据库后执行如下的查询语句

select a a 表空间名称 c c 类型 c c 区管理 b b / / 表空间大小M (b b a a )/ / 已使用M substr((b b a a )/b b ) 利用率from(select tablespace_name a sum(nvl(bytes )) a from dba_free_space group by tablespace_name) a (select tablespace_name b sum(bytes) b from dba_data_files group by tablespace_name) b (select tablespace_name c contents c extent_management c from dba_tablespaces) cwhere a a =b b and c c =b b ;

该语句通过查询dba_free_space dba_data_files dba_tablespaces这三个数据字典表 得到了表空间名称 表空间类型 区管理类型 以 兆 为单位的表空间大小 已使用的表空间大小及表空间利用率 dba_free_space表描述了表空间的空闲大小 dba_data_files表描述了数据库中的数据文件 dba_tablespaces表描述了数据库中的表空间

上面语句中from子句后有三个select语句 每个select语句相当于一个视图 视图的名称分别为a b c 通过它们之间的关联关系 我们得到了表空间的相关信息

语句执行结果如下

上面描述中分别介绍了查看Oracle数据库中表空间信息的工具方法和命令方法

二 查询Oracle数据库中数据文件信息的方法

查看Oracle数据库中数据文件信息的工具方法

使用上面介绍过的方法登录oracle enterprise manager console工具 选择 存储 ——数据文件 会看到如下的界面 该界面显示了数据文件名称 表空间名称 以 兆 为单位的数据文件大小 已使用的数据文件大小及数据文件利用率

查看Oracle数据库中数据文件信息的命令方法

通过查询数据库系统中的数据字典表(data dictionary tables)获取数据文件的相关信息 首先使用客户端工具连接到数据库 这些工具可以是SQLPLUS字符工具 TOAD PL/SQL等 连接到数据库后执行如下的查询语句

select b file_name 物理文件名 b tablespace_name 表空间 b bytes/ / 大小M (b bytes sum(nvl(a bytes )))/ / 已使用M substr((b bytes sum(nvl(a bytes )))/(b bytes) ) 利用率from dba_free_space a dba_data_files bwhere a file_id=b file_idgroup by b tablespace_name b file_name b bytesorder by b tablespace_name

上面描述中分别介绍了查看Oracle数据库中数据文件信息的工具方法和命令方法

三 查看临时表空间和数据库文件的方法

在oracle数据库中 临时表空间主要用于用户在使用order by group by语句进行排序和汇总时所需的临时工作空间 要查询数据库中临时表空间的名称 大小及数据文件 可以查询数据字典dba_tablespaces及dba_data_files 命令如下

select a talbespace_name 表空间名称 b bytes 大小bytes b file_name 数据文件名from dba_tablespaces a dba_data_files bWhere a talbespace_name=b talbespace_name and ntents= TEMPORARY ;

查询结果如下

从oracle i开始 可以创建Temporary tablespace类表空间 即 临时 表空间 这类表空间使用临时文件 临时文件的信息被存储在数据字典V$tempfile中 命令如下

Select file# status name from V$tempfile;

查询数据字典V$tempfile结果如下

在上面介绍的方法中 建议掌握命令方法 因为你的环境可能没有图形工具 而SQLPLUS一般情况下都是可以使用的 有了命令脚本 很容易得到表空间和数据文件的相关信息 另外 数据库管理员应该多整理命令脚本 在需要时直接执行脚本以提高工作效率

lishixinzhi/Article/program/Oracle/201311/18471

可直接在第三方软件中执行,也可在oracle自带的sqlplus中执行。

一、第三方软件(如plsql)

1、登录到指定数据库。

2、点击左上角像纸片的按钮,选择sql窗口。

3、编写select where的语句后,点击执行按钮,如图:

4、则数据内容会显示在下方:

二、用oracle自带的sqlplus执行

1、点击开始菜单,在搜索框输入“cmd”并回车,进入命令提示符。

2、输入“sqlplus”,然后回车。

3、正确填写用户名及密码,登录成功后会有提示,如图:

4、输入查询语句,并一定要以分号结尾。

5、点击回车,即可出现结果,如图:

以上就是关于oracle数据库条件判断的查询语句怎么写全部的内容,包括:oracle数据库条件判断的查询语句怎么写、oracle,查询语句,大神翻译一下、oracle语句查询等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/9499706.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-29
下一篇 2023-04-29

发表评论

登录后才能评论

评论列表(0条)

保存