SQLDevelop

1. 查看数据库版本 :  select  *  from   v$version;

2. 查看表结构:        desc     TABLE_NAME

3. 查看当前连接用户:  select  *  from  v$session;     (show user;  在SQLPlus中显示当前用户名)

4. 查看当前被锁定的表:

SELECT    OSUSER, machine, object_name, s.sid, s.serial#
FROM      gv$locked_object l  ,  
              dba_objects     o,    
            gv$session    s
WHERE    l.object_id  = o.object_id
AND               l.session_id = s.sid

5.   解锁被锁定的表: alter system kill session 'sid, serial#';     (e.g:  : alter system kill session  '23, 4561'  )

6.   NVL函数,处理空值null :    SELECT   id,   NVL(name, 'name_is_null')  from  STU1;   -- 如果STU1表中,name字段为null, 则用name_is_null替换.

7. 查询当前用户下是否有某个表: SELECT  COUNT(1)  FROM USER_TABLES  WHERE TABLE_NAME='STU12'; --如果存在为1, 不存在为0

8. 查询某个用户下是否有某个表:  select count(1) from dba_tables  where   owner = 'USER_NAME' and table_name = 'TABLE_NAME';

9. 查看当前用户下是否有某个(Package/Procedure/Function) :

SELECT   *  FROM  USER_PROCEDURES   OBJECT_TYPE=' FUNCTION| PROCEDURE | PACKAGE'

10. 查看所有用户  SELECT  *  FROM  all_users;

11. Sequence 的用法

create sequence  mysql
START WITH 1
INCREMENT BY 1
NOMAXVALUE
NOMINVALUE
NOCYCLE -- if CYCLE 1000 表示增长到1000之后又从1开始
NOCACHE

12.    union,  union all,  intersect,  minus 的操作

- union all  将结果集累加  (包含重复记录)
SELECT * FROM STU1
union all
SELECT * FROM STU2
-- union 将结果集累加(去除重复)
SELECT * FROM STU1
union
SELECT * FROM STU2 -- intersect 去结果集的: 交集
SELECT * FROM STU1
intersect
SELECT * FROM STU2 -- minus 去结果集的: 差集 (将第一个select所得结果, 减去 所有出现在 第二select的结果)
SELECT * FROM STU1
minus
SELECT * FROM STU2

13.   oracle  数据的五种对象:别名(synonym) ,  序列(Sequence),  视图(View),  索引(Index)  ,  族(cluser).

14.   sign(num)的用法:

if  num > 0,   sign(num) =1;

if  num =0,   sign(num) =0;

if  num <0 , sign(num) = -1;

15. decode 函数用法:

Usage#1:    decode( expression , search , result [, search , result]... [, default] )
select  decode(id,   1, '#1', 
2, '#2',
3, '#3',
4, '#4',
'#Default NO#'),
name
from STU1; -- 将id为1,2,3,4分别转义为#1,#2,#3,#4, 如果不是1,2,3,4则转换为 #Default NO# :

Usage#2:  decode((date1 - date2) - abs(date1 - date2), 0, date2, date1)  --  比较2个中大小,返回较小的一个

Usage#3: 结合sign(num)函数,判断学生成绩 >=80 为优秀, 60<=  score <80  为良好,  socre < 60 为不及格

  select  id, name ,score, decode(sign(score-80), 1 , '优秀', 0, '优秀', -1,
decode(sign(score-60), 1, '良好', 0, '良好', -1 ,'不及格') )
from STU1;

16.  trunc( number, [ decimal_places ] ) 用法(decimal_places必须为>=0的整数,将number后面多余的位数抹掉,不足的位数,保留原有的摸样)

trunc(125.815)        would return 125
trunc(125.815, 0) would return 125
trunc(125.815, 1) would return 125.8
trunc(125.815, 2) would return 125.81
trunc(125.81, 3) would return 125.81
trunc(-125.815, 2) would return -125.81
trunc(125.815, -1) would return 120
trunc(125.815, -2) would return 100
trunc(125.81, -3) would return 0 如果decimal_places 大于number 本身的小数位数,返回原数字不会加0.
如:trunc(125.81,3) would return 125.81;
如果decimal_places 为负数,那么将指定的位数设置为0

17.  查询哪些用户连接到数据库了,并且他们的IP地址分别是什么?

17-1.   缺省从 v$session 中不能直接获得客户端 IP,可以在数据库中创建一个追踪客户端IP地址的触发器:

create or replace trigger on_logon_trigger after logon on database
begin
dbms_application_info.set_client_info(sys_context('userenv', 'ip_address'));
end;

17-2.  退出之后,当用户重新登录时,可以查看IP地址

    select sid,serial#,username,program,machine,client_info
from v$session
where username is not null
order by username,program,machine;

18.  SYSTEM  用户忘记密码

D:\oracle\product\11.2.\dbhome_1\BIN>sqlplus /nolog

SQL*Plus: Release 11.2.0.1. Production on 星期四 7月  :: 

Copyright (c) , , Oracle.  All rights reserved.

SQL> conn /as sysdba
已连接。
SQL> alter user SYSTEM identified by 新密码; 用户已更改。 SQL> exit

19.  复制表

ORACLE 如果表不存在:   
  只复制表结构:create table T_COLUMN_BK as select * from T_COLUMN WHERE 1<>1; //如果只是复制部分字段,可以用具体的字段列表代替 *
表结构+数据: create table T_COLUMN_BK as select * from T_COLUMN ; //如果只是复制部分字段,可以用具体的字段列表代替 * ORACLE 如果表已经存在:
复制表数据: INSERT INTO T_COLUMN_BK SELECT * FROM T_COLUMN

20.   查询当前数据库实例名称:     SELECT    instance_name   FROM   v$instance; 

21,   查询当前数据库名称:           SELECT    name      FROM   v$database;

默认情况下,数据库实例名称和数据库名称相同。

22.   NVL() 函数的使用

-- NVL(expr1,  expr2)        if   expr1==null,  return expr2;    e.g:     NVL(null, 'aa' )   ---> aa ;

if   expr1 != null,  return expr1;  e.g :     NVL('xx', 'aa' )----> xx

-- NVL2(expr,  expr1,  expr2)       if  expr == null,    return expr2;    e.g:   NVL2(null, 'aa', 'bb')   ----->bb

if  expr != null,     return  expr1;    e.g:   NVL2('xxx', 'aa', 'bb')  ---->aa

Oracle 基础知识的更多相关文章

  1. 图说Oracle基础知识(一)

    本文主要对Oralce数据库操作的基础知识进行一下梳理,以便进行归纳总结.适用于未使用过Oracle数据库的读者,或需要学习Oracle数据库方面的基础知识.如有不足之处,还请指正. 关于SQL介绍的 ...

  2. Oracle基础知识汇总一

    Oracle基础知识 以下内容为本人的学习笔记,如需要转载,请声明原文链接   https://www.cnblogs.com/lyh1024/p/16720759.html oracle工具: SQ ...

  3. Oracle 基础知识入门

    前记: 近来项目用到Oracle数据库,大学学了点,后面基本忘记得差不多了,虽然基本语法跟sql 差不多,但是oracle知识是非常多的. 这里简单说点基础知识,希望后面补上更多的关于ORacle知识 ...

  4. Oracle基础知识笔记(10) 约束

    表尽管建立完毕了,可是表中的数据是否合法并不能有所检查,而假设要想针对于表中的数据做一些过滤的话,则能够通过约束完毕,约束的主要功能是保证表中的数据合法性,依照约束的分类,一共同拥有五种约束:非空约束 ...

  5. 2008-03-18 22:58 oracle基础知识小结

    oracle 数据类型: 字段类型                 中文说明                                                  限制条件         ...

  6. oracle基础知识过一遍(原创)

    用户.角色.权限.表空间 create tablespace test1_tablespace datafile ‘test1file.dbf’ size 10m; create temporary  ...

  7. oracle 基础知识(七)----动态性能视图

    一,动态性能视图介绍 动态性能视图属于数据字典,系统管理员用户 SYS 可以访问它们.在数据库打开和使用时不断进行更新,而且它们的内容主要与性能有关.虽然这些视图很像普通的数据库表,但它们不允许用户直 ...

  8. oracle 基础知识(三)

    一.删除oracle 进入注册表到HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\OracleOraHome91TNSListener Ima ...

  9. oracle基础知识语法大全

    ORACLE支持五种类型的完整性约束NOT NULL (非空)--防止NULL值进入指定的列,在单列基础上定义,默认情况下,ORACLE允许在任何列中有NULL值.CHECK (检查)--检查在约束中 ...

  10. oracle基础知识及语法

    ORACLE支持五种类型的完整性约束 NOT NULL (非空)--防止NULL值进入指定的列,在单列基础上定义,默认情况下,ORACLE允许在任何列中有NULL值. CHECK (检查)--检查在约 ...

随机推荐

  1. [置顶] 第一天初试linux

    1).unix  linix  macos android 的区别 Unix是要收费的,而linix是一种开源免费的unix ,macos 和andorid又是linux的一种,macos闭源,仅仅是 ...

  2. IEnumerable 和 IQueryable

    共有两组 LINQ 标准查询运算符,一组在类型为 IEnumerable<T> 的对象上运行,另一组在类型为 IQueryable<T> 的对象上运行.构成每组运算符的方法分别 ...

  3. Eclipse SVN插件账号、密码修改

    操作系统:win7 svn插件:Window -> Preferences -> Team -> SVN 修改方式: 1,删除C:\Users\用户名\AppData\Roaming ...

  4. 异步任务(AsyncTask)

    Android的UI线程主要负责处理用户的按键事件.用户触屏事件及屏幕绘图事件等,因此开发者的其他操作不应该.也不能阻塞UI线程,否则UI界面将会变得停止响应——用户感觉非常糟糕.(总之,开发者需要牢 ...

  5. YII中URL地址美化

    URL地址美化:urlManager地址管理(通过程序来实现url的地址美化) 例如: 原地址:http://localhost/项目/app/index.php?r=控制器/方法 新地址:http: ...

  6. css实现基础几何图形

    我们知道,css3通过border-radius.animation.transform等“新”特性可以绘制很多精致的图形.比如腾讯企鹅Logo.超能陆战队中的大白机器人.太阳系.小黄人.叮当猫.安卓 ...

  7. FromHandle函数

    一 FromHandle() MFC 实际上是对内核对象HANDLE(如CDC的m_hDC,CWnd的m_hWnd)封装了这个句柄有关的所有操作,一个类生成一个新对象的时候这个句柄是无效的,要获得这个 ...

  8. Web前端开发如何利用css样式来控制Html中的h1/h2/h3标签不换行

      H1/H2/H3/H4标题标签常常使用在一个网页中唯一标题.重要栏目.重要标题等情形下. H1在一个网页中最好只使用一次,如对一个网页唯一标题使用.H2.H3.H4标签则可以在一个网页中多次出现, ...

  9. Ubuntu12.04 下安装Qt

    1.下载Qt Creator 链接  http://qt-project.org/downloads 选择 Qt Creator 2.8.0 for Linux/X11 32-bit (61 MB) ...

  10. Solr4.7新建core

    Solr里面的core就像数据库里面的一个表,用来管理索引和相关配置. 一. 使用示例core 下载的solr完整包里面solr-4.7.0\example\multicore这个文件夹下面有2个示例 ...