![]() |
#2
潇洒老乌龟2006-08-17 21:58
|
怎么才能学好Oracle啊?谢谢



![]() |
#2
潇洒老乌龟2006-08-17 21:58
类似SQL的查询分析器
|
![]() |
#3
潇洒老乌龟2006-08-17 22:04
ORACLE的SQLPLUS常用命令 a、启动ORACLE系统 b、关闭ORACLE系统 启动oracle9i数据库命令: SQL*Plus: Release 9.2.0.1.0 - Production on Fri Oct 31 13:53:53 2003 Copyright (c) 1982, 2002, Oracle Corporation. All rights reserved. SQL> connect / as sysdba SQL> startup 2、在双机环境下 a、启动ORACLE系统 b、关闭ORACLE系统 Oracle数据库有哪几种启动方式 说明: 有以下几种启动方式: 读取init.ora文件,启动instance,即启动SGA和后台进程,这种启动只需要init.ora文件。 2、startup mount dbname 执行“nomount”,然后打开控制文件,确认数据文件和联机日志文件的位置, 3、startup open dbname 4、startup,等于以下三个命令 5、startup restrict 6、startup force 7、startup pfile=参数文件名 8、startup EXCLUSIVE 数据字典里存有用户信息、用户的权限信息、所有数据对象信息、表的约束条件、统计分析数据库的视图等。 很多时候,一般的ORACLE用户不知道如何有效地利用它。 dictionary 全部数据字典表的名称和解释,它有一个同义词dict 如果我们想查询跟索引有关的数据字典时,可以用下面这条SQL语句: SQL>select * from dictionary where instr(comments,'index')>0; 如果我们想知道user_indexes表各字段名称的详细含义,可以用下面这条SQL语句: SQL>select column_name,comments from dict_columns where table_name='USER_INDEXES'; 依此类推,就可以轻松知道数据字典的详细名称和解释,不用查看ORACLE的其它文档资料了。 下面按类别列出一些ORACLE用户常用数据字典的查询使用方法。 1、用户 查看当前用户的缺省表空间 查看当前用户的角色 查看当前用户的系统权限和表级权限 2、表 查看用户下所有的表 查看名称包含log字符的表 查看某表的创建时间 查看某表的大小 查看放在ORACLE的内存区里的表 3、索引 查看索引个数和类别 查看索引被索引的字段 查看索引的大小 4、序列号 查看序列号,last_number是当前值 5、视图 查看视图的名称 查看创建视图的select语句 6、同义词 查看同义词的名称 7、约束条件 查看某表的约束条件 SQL>select c.constraint_name,c.constraint_type,cc.column_name 8、存储函数和过程 查看函数和过程的状态 查看函数和过程的源代码 三、查看数据库的SQL select t.tablespace_name, round(sum(bytes/(1024*1024)),0) ts_size 2、查看表空间物理文件的名称及大小 select tablespace_name, file_id, file_name, 3、查看回滚段名称及大小 select segment_name, tablespace_name, r.status, 4、查看控制文件 select name from v$controlfile; 5、查看日志文件 select member from v$logfile; 6、查看表空间的使用情况 select sum(bytes)/(1024*1024) as free_space,tablespace_name SELECT A.TABLESPACE_NAME,A.BYTES TOTAL,B.BYTES USED, C.BYTES FREE, 7、查看数据库库对象 select owner, object_type, status, count(*) count# from all_objects group by owner, object_type, status; 8、查看数据库的版本 Select version FROM Product_component_version 9、查看数据库的创建日期和归档方式 Select Created, Log_Mode, Log_Mode From V$Database; |
![]() |
#4
潇洒老乌龟2006-08-17 22:04
四、ORACLE用户连接的管理 用系统管理员,查看当前数据库有几个用户连接: SQL> select username,sid,serial# from v$session; 如果要停某个连接用 SQL> alter system kill session 'sid,serial#'; 如果这命令不行,找它UNIX的进程数 SQL> select pro.spid from v$session ses,v$process pro where ses.sid=21 and ses.paddr=pro.addr; 说明:21是某个连接的sid数 然后用 kill 命令杀此进程号。 五、SQL*PLUS使用 退出SQL*Plus b、在sqlplus下得到帮助信息 c、显示表结构命令DESCRIBE d、SQL*Plus中的编辑命令 修改SQL命令 使用INPUT命令可以在SQL缓冲区中增加一行或多行 e、调用外部系统编辑器 f、运行命令文件 常用SQL*Plus语句 为基表增加新列命令如下: 修改基表列定义命令如下: b、将一张表删除语句的格式如下: c、表空间的创建、删除 六、ORACLE逻辑备份的SH文件 完全备份的SH文件:exp_comp.sh rq=` date +"%m%d" ` su - oracle -c "exp system/manager full=y inctype=complete file=/oracle/export/db_comp$rq.dmp" 累计备份的SH文件:exp_cumu.sh rq=` date +"%m%d" ` su - oracle -c "exp system/manager full=y inctype=cumulative file=/oracle/export/db_cumu$rq.dmp" 增量备份的SH文件: exp_incr.sh rq=` date +"%m%d" ` su - oracle -c "exp system/manager full=y inctype=incremental file=/oracle/export/db_incr$rq.dmp" root用户crontab文件 0 2 1 * * /oracle/exp_comp.sh 30 2 * * 0-5 /oracle/exp_incr.sh 45 2 * * 6 /oracle/exp_cumu.sh 当然这个时间表可以根据不同的需求来改变的,这只是一个例子。 七、ORACLE 常用的SQL语法和数据对象 一.数据控制语句 (DML) 部分 1.INSERT (往数据表里插入记录的语句) INSERT INTO 表名(字段名1, 字段名2, ……) VALUES ( 值1, 值2, ……); 字符串类型的字段值必须用单引号括起来, 例如: ’GOOD DAY’ 日期字段的字段值可以用当前数据库的系统时间SYSDATE, 精确到秒 INSERT时最大可操作的字符串长度小于等于4000个单字节, 如果要插入更长的字符串, 请考虑字段用CLOB类型, INSERT时如果要用到从1开始自动增长的序列号, 应该先建立一个序列号 2.DELETE (删除数据表里记录的语句) DELETE FROM表名 WHERE 条件; 注意:删除记录并不能释放ORACLE里被占用的数据块表空间. 它只把那些被删除的数据块标成unused. 如果确实要删除一个大表里的全部记录, 可以用 TRUNCATE 命令, 它可以释放占用的数据块表空间 3.UPDATE (修改数据表里记录的语句) UPDATE表名 SET 字段名1=值1, 字段名2=值2, …… WHERE 条件; 如果修改的值N没有赋值或定义时, 将把原来的记录内容清为NULL, 最好在修改前进行非空校验; 注意事项: B. 在运行INSERT, DELETE 和 UPDATE 语句前最好估算一下可能操作的记录范围, 二.数据定义 (DDL) 部分 1.CREATE (创建表, 索引, 视图, 同义词, 过程, 函数, 数据库链接等) ORACLE常用的字段类型有 创建表时要把较小的不为空的字段放在前面, 可能为空的字段放在后面 创建表时可以用中文的字段名, 但最好还是用英文的字段名 创建表时可以给字段加上默认值, 例如 DEFAULT SYSDATE 创建表时可以给字段加上约束条件 2.ALTER (改变表, 索引, 视图等) 改变表的名称 在表的后面增加一个字段 修改表里字段的定义描述 给表里的字段加上约束条件 把表放在或取出数据库的内存区 3.DROP (删除表, 索引, 视图, 同义词, 过程, 函数, 数据库链接等) 删除表和它所有的约束条件 4.TRUNCATE (清空表里的所有记录, 保留表的结构) TRUNCATE 表名; 三.查询语句 (SELECT) 部分 SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] WHERE 条件; 字段名可以带入函数 NVL(EXPR1, EXPR2)函数 DECODE(AA﹐V1﹐R1﹐V2﹐R2....)函数 ELSE LPAD(char1,n,char2)函数 字段名之间可以进行算术运算 查询语句可以嵌套 两个查询语句的结果可以做集合操作 分组查询 两个以上表之间的连接查询 SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] WHERE SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] WHERE 有(+)号的字段位置自动补空值 查询结果集的排序操作, 默认的排序是升序ASC, 降序是DESC SELECT字段名1, 字段名2, …… FROM 表名1, [表名2, ……] 字符串模糊比较的方法 INSTR(字段名, ‘字符串’)>0 每个表都有一个隐含的字段ROWID, 它标记着记录的唯一性. 四.ORACLE里常用的数据对象 (SCHEMA) 1.索引 (INDEX) CREATE INDEX 索引名ON 表名 ( 字段1, [字段2, ……] ); 一个表的索引最好不要超过三个 (特殊的大表除外), 最好用单字段索引, 结合SQL语句的分析执行情况, ORACLE8.1.7字符串可以索引的最大长度为1578 单字节 2.视图 (VIEW) CREATE VIEW 视图名AS SELECT …. FROM …..; 视图仅是一个SQL查询语句, 它可以把表之间复杂的关系简洁化. 3.同义词 (SYNONMY) 4.数据库链接 (DATABASE LINK) 数据库连接字符串可以用NET8 EASY CONFIG或者直接修改TNSNAMES.ORA里定义. 数据库参数global_name=true时要求数据库链接名称跟远端数据库名称一样 数据库全局名称可以用以下命令查出 查询远端数据库里的表 五.权限管理 (DCL) 语句 1.GRANT 赋于权限 GRANT CONNECT, RESOURCE TO 用户名; 2.REVOKE 回收权限 REVOKE CONNECT, RESOURCE FROM 用户名;
查询数据库中开户用户最大提交和最大下发数: select MSISDN,TCOS,OCOS from ms_usertable;
查询报表数据库中话单统计种类查询。 |
![]() |
#5
HGC20062006-08-18 09:30
谢谢,版主,
![]() ![]() ![]() |
![]() |
#6
xiaoyao_20042006-10-17 20:52
![]() |
![]() |
#7
v々梦2006-10-26 10:06
说的非常的详细,顶!
我也是往这方面走的,希望版主多多指教指教! ![]() |
![]() |
#8
路過2007-01-04 15:06
謝謝, |