系统函数:sys_context
terminal:当前会话客户所对应的终端的标示符
language:语言
db_name:当前数据库名称
nls_date_formal:当前会话客户所对应的日期格式
session_user:当前会话客户所对应的数据库用户名
current_schema:当前会话客户所对应的默认方案名
host:返回数据库所在主机的名称
通过该函数,可以查询一些重要信息,比如你在使用哪个数据库:
Select sys_context(‘userenv’,’db_name’)from dual;(userenv固定格式)
连接sys数据库的方法:
Connsys/change_on_install as sysdba;
启动数据库:startup
关闭数据库:shutdown
管理初始化参数:
初始化参数用于设置实例或是数据库的特征,oracle9i提供了200多个初始化参数,并且每个初始化参数都有默认值。
显示初始化参数
show parameter命令
如果想修改这些初始化参数,可以到文件:
D:\oracle\admin\myoral\pfile\init.ora文件中去修改
导出:
导出具体分为:导出方案,导出表,导出数据库三种方式
(2) 导出使用exp命令来完成,该命令常用的选项用:
Userid:用于指定执行导出操作的用户名,口令,链接字符串
Tables:用于指定执行导出操作的表
Owner:用于指定执行导出操作的方案
Inctype:用于指定执行导出操作的增量类型
Rows:用于指定执行导出操作是否要导出表中的数据
File:用于指定导出文件名
导出自己的表:(注意exp字母e的小写)
expuserid=wangzihu/wangzihu@sjjz tables=(bbs,book) file=c:\mysql.dmp;(在导入和导出的时候,要到oracle目录的bin/exp.exe文件目录下进行导入和导出或用cmd命令)
(3)导出表的结构
expuserid=wangzihu/wangzihu@sjjz tables=(bbs) file=d:\e3.dmprows=n;
(4)使用直接导出方式
exp userid=wangzihu/wangzihu@sjjz tables=(bbs)file=d:\e3.dmpdirect=y;
这种方式比默认的常规方式速度要快,当数据量大时,可以考虑使用这样的方法
导出方案:
导出自己的方案(导出所有的对象,包括所有表,视图,触发器,存储过程等)
expwangzihu/wangzihu@sjjz owner=wangzihufile=d:\wangzihu.dmp;
导入
导入表:
导入自己表
Imp userid=wangzihu/wangzihu@sjjz tables=(bbs)file=d:\e3.dmp;
2)导入表到其它用户
要求该用户具有dba的权限,或是imp_full_database
Imp userid=system/manager@myortables=(emp) file=d:\xx.dmp;
3)导入表的结构
只导入表的结构而不导入数据
Imp userid=wangzihu/wangzihu@sjjztables=(bbs) file=d:\e3.dmp rows=n;
4)导入数据
如果对象(比如表)已经存在可以导入表的数据
Imp userid=wangzihu/wangzihu@sjjztables(bbs) file=d:\e3.dmp ignore=y;
导入方案:
导入自身的方案
Imp userid=wangzihu/wangzihufile=d:\wangzihu.dmp
导入数据库:
在默认情况下,当导入数据库时,会导入所有对象结构和数据,案例如下:
Impuserid=system/manager full=y file=d:\xxx.dmp
数据字典:数据字典是oracle数据库中最重要的组成部分,它提供了数据的一些系统信息。
动态性能视图记载了例程启动后的相关信息。
user_tables:
用于显示当前用户所拥有的所有表,它只返回用户所对应方案的所有表
比如:selecttable_name from user_tables;
all_tables:
用于显示当前用户可以访问的所有表,它不仅会返回当前用户方案的所有表,还会返回当前用户可以访问的其它方案的表:
比如:selecttable_name from all_tables;
Dba_tables:
它会显示所有方案拥有的数据库表,但是查询这种数据库字典视图,要求
用户必须是dba角色或是select anytable系统权限。
例如:当用system用户查询数据字典视图dba.tables时,会返回system,sys,scott…方案所对应的数据库表。
比如:selecttable_name from dba_tables;
用户,权限,角色
在建立用户时,oracle会把用户的信息存放到数据字典中,当给用户授予权限或是角色时,oracle会将权限和角色的信息存放到数据字典。
通过查询dba.users可以显示素有数据库用户的详细信息;
通过查询数据字典视图dba_sys_privs,可以显示用户所具有的系统权限;
通过查询数据字典视图dba_tab_privs可以显示用户具有的对象权限;
通过查询数据字典dba_col_privs可以显示用户具有的列权限;
通过查询数据字典视图dba_role_privs可以显示用户所具有的角色
比如:1)selectusername from dba_users(username固定格式)
2)Select * from dba_role_privs whereGRANTEE='WANGZIHU';(WANGZIHU注意大写)
查看oracle中所有角色:
Select * from dba_roles;
查询oracle中所有的系统权限,一般是dba:
Select * from system_privilege_maporder by name;
查询oracle中所有对象权限,一般是dba:
Select distinct privilege fromdba_tab_privs;
一个角色包含的系统权限
Select * fromdba_sys_privswhere grantee=’DBA’;
或者这样也可以
Select * fromrole_sys_privswhere role=’DBA’;
一个角色包括的对象权限
Select * fromdba_tab_privswhere grantee=’DBA’;
如何查看某个用户具有什么样的角色?
Select * fromdba_role_privswhere grantee=’WANGZIHU’;
显示当前用户可以访问的所有数据字典视图
Select * from dict where commentslike ‘%grant%’;
显示当前数据库的全称
Select * from global_name;