- 浏览: 416387 次
- 性别:
- 来自: 深圳
文章分类
最新评论
-
skying007:
...
Mysql coalesce() 函数认识和用法 -
kchiu:
关于这个心跳的发送和接收 晚上全是the fuccking s ...
socket心跳检测 -
bjsq618:
你的想法在大的物流公司已经实现了,只不过他们使用是GPS定位
ddd -
jiaguwen123:
2,AuthenticationHandler类的写法
pa ...
xfire客户端 -
sornor:
总结的不错哟!
Java中的函数yield(),sleep()和wait()的区别
一、oracle数据库结构
服务器参数文件oracle\product\10.1.0\Db_2\database\spfile*.ora
oracle\10.1.0\oradata\
1.参数文件
2.*.CTL 控制文件
3.*.DBF 数据文件
4.*.LOG 日志文件
c:\>sqlplus "sys/password as sysdba"登录系统
SQL>DESC v$controlfile描述控制文件
SQL>SELECT status,name FROM v$controlfile查看控制文件
SQL>DESC v$datafile描述数据文件
SQL>SELECT file#,status,name FROM v$datafile查看数据文件
SQL>DESC v$logfile描述日志文件
SQL>SELECT member FROM v$logfile查看日志文件
ORACLE内存结构
1.SGA总称
2.DB buffer数据缓存区
(默认缓存池,保持缓存池,再生缓存池)
3.Redo buffer日志缓存区
4.共享池
(库缓存区:共享SQL区、PL/SQL区,字典缓存区)
5.大共享池
6.固定SGA
ORACLE逻辑结构
表空间tablespace(块block、盘区extent、段segment)
表空间tablespace(数据文件datafile)
二、sqlplus的使用方法
isqlplus打开方式http://主机名:oracle访问端口/isqplus
isqlplus登录名:scott 密码:tiger
c:\>sqlplus "sys/password as sysdba"登录
c:\>sqlplus/nolog
SQL>connect sys/password as sysdba
SQL>startup
SQL>archive log list
SQL>startup mount正常启动
SQL>alter database archivelog
SQL>alter database open
SQL>startup nomount丢失恢复启动
SQL>shutdown immediate正常关闭
SQL>shutdown等待关闭
SQL>shutdown transactional等待立即关闭
SQL>shutdown abort强制关闭
SQL>help index查看sqlplus帮助命令
SQL>SELECT * FROM dept;
SQL>SET SQLBLANKLINES ON设置sqlplus行输入连接为开
SQL>SELECT * FROM dept WHERE deptno=&tt设置输入参数
Enter value for tt:
SQL>list查看输入缓存区的命令,或者只输入l
SQL>l2 4查看缓存区第二行到第四行的输入
SQL>change修改刚刚输入的语句,或者只输入c
SQL>c/N/M用M替换N
SQL>/执行缓存区里的命令
SQL>? CHANGE说明某个命令的用法,比如CHANGE
SQL>DEL 4删除缓存区某一行的命令,比如第四行
SQL>DEL 2 3
SQL>save c:\oracle\test.txt将缓存区中的命令保存到文件中
SQL>get c:\oracle\test.txt获取文件中的命令
SQL>edit 调用记事本编辑刚刚输入的语句
SQL>COLUMN deptno HEADING "编号"为查询的某一列别名显示,或者写成COL方法
SQL>SELECT * FROM dept;
SQL>DESCRIBE用于描述一个对象,或者写成DESC
SQL>DESC dept比如描述dept表的结构
SQL>COL dname FORMAT A10为某列格式化显示
SQL>COL dname FORMAT A1O HEADING "部门名称"
SQL>SELECT * FROM dept;
SQL>exit退出sqlplus模式,退出后缓存中的别名列自动消失
SQL>sqlplus scott/tigger,通过scott方式登录,不需要引号
SQL>COL deptno FORMAT 999,999,999格式化显示
SQL>connect "sys/test1234 as sysdba"通过sysdba查看数据文件的大小,以999,999,999格式显示
SQL>SELECT byte FORM v$datafile
SQL>SELECT byte,name FROM v$datafile
SQL>connect scott/tiger
SQL>SET LINESIZE 50一次查看多少列
以下是为查看数据设置左、中、右标题
SQL>TTITLE CENTER "我的标题" SKIP 1-
>LEFT "测试报表" RIGHT "页"-
>FOTMAT 999 SQL.PNO SKIP 2
SQL>SELECT * FROM dept;
SQL>BREAK ON pub在某一列上相同值不显示,如在pub列上
SQL>COMPUTE COUNT LABEL "计数" OF books_name ON pub
查询pub列名称相同的books_name的统计结果,显示为计数
SQL>spool c:\oracle\spool.txt将查询结果保存到文件中,表示开始点
以下是要查询保存的语句,将查询结果保存到spool.txt中
SQL>SELECT * FROM books;
SQL>spool off表示查询结果保存结束点
SQL>edit c:\oracle\spool.txt用记事本打开spool.txt文件,查看保存是否成功
二、结构化查询语句
1.DDL
CREATE
ALTER
DROP
2.DCL
GRANT
REVOKE
3.DML
SELECT
INSERT
DELETE
UPDATE
SQL>connect scott/tiger
SQL>CREATE TABLE abc(a varchar2(10), b char(10));
SQL>ALTER TABLE abc ADD c number;
SQL>ALTER TABLE abc DROP COLUMN c;
SQL>connect tt/tt11
SQL>SELECT * FROM scott.dept;
SQL>conn scott/tiger
SQL>GRANT SELECT ON dept TO tt;
SQL>conn tt/tt11
SQL>SELECT * FROM scott.dept;
SQL>conn scott/tiger
SQL>SELECT * FROM abc
SQL>INSERT INTO abc(a,b) VALUES('abc','xy')
SQL>INSERT INTO abc VALUES('bcd','123')
SQL>UPDATE abc SET b='ttt'
SQL>UPDATE abc b='YYY' WHERE a='abc';
SQL>DELETE FROM abc WHERE a='abc';
SQL>SELECT * FROM abc;
常用系统函数
1.字符
SQL>SELECT LENGTH('ABCDEF') FROM dual;
SQL>SELECT LTRIM(' ABCDEF') FROM dual;
SQL>SELECT RTRIM('ABCDEF ') FROM dual;
SQL>SELECT TRIM(' ABCDEF ') FROM dual;
SQL>UPDATE aa SET a3='aa';
SQL>SELECT LENGTH(A2),LENCTH(A3) FROM aa;
SQL>SELECT SUBSTR('abcdefg',2,3) FROM dual;
SQL>SELECT SUBSTR('sbcdefg',LENGTH('qbcdefg')-3+1,3) FROM dual;
REPLACE
2.日期
SQL>SELECT sysdate FROM dual;
SQL>SELECT current_date FROM dual;
SQL>ALTER SESSION SET NLS_DATE_FORMAT='dd-mon-yyyy hh:m1:ss';
SQL>SELECT NEXT_DAY(sysdate,'星期三') FROM dual;
3.转换
SQL>SELECT TO_CHAR(sysdate,'yyyy-mm-dd hh:mi:ss') FROM dual;
SQL>SELECT TO_CHAR(sysdate,'yyyy-mm-dd hh24:mi:ss') FROM dual;
SQL>SELECT TO_DATE('12-3月-04') FROM dual;
SQL>SELECT TO_NUMBER('00333') FROM dual;
4.聚集函数
SQL>SELECT * FROM books
SQL>SELECT max(price) FROM books;
SQL>SELECT min(price) FROM books;
SQL>SELECT sum(price) FROM books;
SQL>SELECT avg(price) FROM books;
SQL>SELECT count(price) FORM books;
SQL>SELECT count(*) FROM books;
SQL>SELECT * FROM books WHERE price>20;
5.其他
SQL>SELECT user FROM dual;
SQL>connect tt/tt11;
SQL>connect scott/tiger;
SQL>SELECT * FROM e;
SQL>SELECT SUM(DECODE(SEX,'男',1,0)) 男人数,SUM(DECODE(SEX,'女',1,0) 女人数 FROM e;判断计数,为真加1,否则加零
SQL>SELECT a1,nvl(a2,'未输入') a2 FROM aa;对空值处理,填充'未输入'
SQL>SELECT * FROM aa WHERE a2=NULL;
SQL>SELECT * FROM aa ORDER BY a1 ASC;
SQL>SELECT * FROM aa ORDER BY a1 DESC;
SQL>SELECT DISTINCT a1 FROM aa;
SQL>SELECT ALL a1 FROM aa;
分组语句
SQL>SELECT * FROM books;
SQL>SELECT sum(price*qty) FROM books
SQL>SELECT sum(price*qty) FROM books GROUP BY pubs;
SQL>SELECT pub,books_name,sum(price*qty) FROM books GROUP BY pubs,books_name;
SQL>SELECT pub,sum(price*qty) FROM books GROUP BY pub,books_name;
SQL>SELECT pub,sum(price*qty) FROM books WHERE price>30 GROUP BY pubs;
SQL>SELECT pub,sum(price*qty) FROM books GROUP BY pub HAVING sum(price)>60;
SQL>SELECT a1,count(a1) FROM aa GROUP BY a1 HAVING COUNT(a1)>1;
模糊查询
SQL>SELECT * FROM aa;
SQL>SELECT * FROM aa WHERE a1 LIKE 'a_';
SQL>SELECT * FROM aa WHERE a1 LIKE 'a%';
SQL>SELECT * FROM aa WHERE a1 LIKE '_a';
SQL>SELECT * FROM aa WHERE a1 LIKE '%a';
SQL>SELECT * FROM aa WHERE a1 LIKE '%a%';
连接查询
SQL>SELECT * FROM e;
SQL>SELECT * FROM d;
SQL>SELECT eid 编号,ename 姓名,sex 性别,d.name 所在部门 FROM employee e,department d WHERE e.id=d.id;
内连接
SQL>SELECT eid 编号,ename 姓名,sex 性别,d.name 所在部门 FROM employee e join department d on e.id=d.id;
以下为外连接
SQL>SELECT eid 编号,ename 姓名,sex 性别,d.name 所在部门 FROM employee e join department d on e.id=d.id(+);
左连接,以左边为主,右边为辅
SQL>SELECT eid 编号,ename 姓名,sex 性别,d.name 所在部门 FROM employee e join department d on e.id(+)=d.id;
右连接,以右边为主,左边为辅
子查询
无关子查询
SQL>SELECT * FROM e WHERE id IN (SELECT id FROM d);
相关子查询,与父表有关
SQL>SELECT * FROM e WHERE id IN (SELECT id FROM d WHERE id=e.id AND id='03');
用IN的方式,子查询的字段要与父查询的条件匹配
判断子查询结果是否存在,存在就执行父查询
SQL>SELECT * FROM e WHERE EXISIS (SELECT id FROM d)
SQL>SELECT * FROM e WHERE NOT EXISIS (SELECT * FROM d WHERE id=e.id);
联合查询
SQL>SELECT e.id,ename FROM e
UNION
SELECT id,name FROM d;
SQL>SELECT id FROM e
UNION
SELECT id FROM d;
返回两个SQL语句中都出现的行,ORACLE数据库特有
SQL>INTERSECT
SQL>SELECT id FROM e
INTERSECT
SELECT id FROM d;
将一个表的查询结果,插入到另外一张表中
SQL>INSERT INTO e(eid,ename) SELECT id,name FROM d;
将一个表的查询结果,插入到新建的一张表中
SQL>CREATE TABLE ttt AS (SELECT * FROM e);
SQL>CREATE TABEL t AS SELECT eid,ename FROM e WHERE eid='001';
SQL>SELECT * FROM t;
四 PL/SQL
PL/SQL块结构
DECLARE
BEGIN
EXCEPTION 异常处理
END
变量声明,命名规则
变量由字符开头,可以包含:数字,下划线,$,#
不能是系统关键字
SQL>DECLARE
2 x varchar2(10);
3 BEGIN
4 x:='This is..'; 赋值的写法
5 DBMS_OUTPUT.PUT_LINE('x的值为:'||x) ||连接加号
6 END;
7 /
SQL> SET SERVEROUTPUT ON SIZE 10000 设置服务器输出大小
SQL> L 显示缓存中的语句
SQL> / PL/SQL执行语句
SQL>DECLARE
2 x varchar2(10);
3 BEGIN
4 x:='This is..'; 赋值的写法
5 DBMS_OUTPUT.PUT_LINE('x的值为:'||x) ||连接加号
6 END;
7 四 PL/SQL
PL/SQL块结构
DECLARE
BEGIN
EXCEPTION 异常处理
END
变量声明,命名规则
变量由字符开头,可以包含:数字,下划线,$,#
不能是系统关键字
SQL>DECLARE
2 x varchar2(10);
3 BEGIN
4 x:='This is..'; 赋值的写法
5 DBMS_OUTPUT.PUT_LINE('x的值为:'||x) ||连接加号
6 END;
7 /
SQL> SET SERVEROUTPUT ON SIZE 10000 设置PL/SQL服务器输出大小
SQL> L 显示缓存中的语句
SQL> / PL/SQL执行语句
SQL>DECLARE
2 x varchar2(10);
3 BEGIN
4 x:='This is..'; 赋值的写法
5 --DBMS_OUTPUT.PUT_LINE('x的值为:'||x); 注释掉了
DBMS_OUTPUT.PUT('x的值为:'||x);
DBMS_OUTPUT.NEW_LINE; 在一个新行显示
6 END;
7 /
多行注释用/* */
SQL>DECLARE
2 x varchar2(10);
y INTEGER:=123;
3 BEGIN
4 x:='This is..'; 赋值的写法
5 --DBMS_OUTPUT.PUT_LINE('x的值为:'||x); 注释掉了
DBMS_OUTPUT.PUT('x的值为:'||x||y);
DBMS_OUTPUT.NEW_LINE; 在一个新行显示
6 END;
7 /
SQL>save c:/plsql_01.txt 保存到文件
SQL>@ c:/plsql_01.txt 调用文件
SQL>DECLARE
2 x varchar2(10);
y string(10):=123; 必须给定长度string
3 BEGIN
4 x:='This is..'; 赋值的写法
5 --DBMS_OUTPUT.PUT_LINE('x的值为:'||x); 注释掉了
DBMS_OUTPUT.PUT('x的值为:'||x||y);
DBMS_OUTPUT.NEW_LINE; 在一个新行显示
6 END;
7 /
SQL>DECLARE
2 a number;
3 b varchar2(10);
4 BEGIN
5 a:=2;
6 IF a=1 THEN
7 b:='A';
8 ELSEIF a=2 THEN
9 b:='B';
10 ELSE
11 b:='C'
12 END IF;
13 DBMS_OUTPUT.PUT_LINE('b的值是:'||b);
14 END;
15 /
SQL>save c:/plsql_02.txt 保存到文件
SQL>@ c:/plsql_02.txt 调用文件
DECLARE
a number;
b varchar2(10);
BEGIN
a:=2;
CASE
WHEN a=1 THEN b:='A'
WHEN a=2 THEN b:='B'
WHEN a=3 THEN b:='C'
ELSE
b:='Others';
END CASE;
DBMS_OUTPUT.PUT_LINE('b的值是:'||b);
END;
/
循环语句
基本循环
SQL>DECLARE
x number;
BEGIN
x:=0;
LOOP
x:=0
LOOP
x:=x+1
IF x>3 THEN
EXIT;
END IF;
DBMS_OUTPUT.PUT_LINE('内:x='||x);
END LOOP;
DBMS_OUTPUT.PUT_LINE('外:x='||x);
END;
/
内:x=1
内:x=2
外:x=3
SQL>save c:\plsql_loop01.txt
created file c:\plsql_loop01.txt
SQL>edit c:\plsql_loop01.txt
SQL>@ c:\plsql_loop01.txt
WHILE循环
SQL>DECLARE
x number;
BEGIN
x:=0;
LOOP
x:=0
LOOP
x:=x+1
EXIT WHEN x>3;
END IF;
DBMS_OUTPUT.PUT_LINE('内:x='||x);
END LOOP;
DBMS_OUTPUT.PUT_LINE('外:x='||x);
END;
SQL>DECLARE
x number;
BEGIN;
x:=0;
WHILE x<3 LOOP;
x:=x+1;
DBMS_OUTPUT.PUT_LINE('内:x='||x);
END LOOP;
DBMS_OUTPUT.PUT_LINE('外:x='||x);
/
内:x=1
内:x=2
内:x=3
内:x=4
外:x=4
SQL>save c:\plsql_loop03.txt
FOR循环
SQL>BEGIN
FOR i in 1..5 LOOP
DBMS_OUTPUT.PUT_LINE('i='||i);
END LOOP;
DBMS_OUTPUT.PUT_LINE('END OF FOR LOOP');
END;
/
SQL>BEGIN
FOR i in REVERSE 1..5 LOOP从大到小循环
DBMS_OUTPUT.PUT_LINE('i='||i);
END LOOP;
DBMS_OUTPUT.PUT_LINE('END OF FOR LOOP');
END;
/
SQL>save c:\plsql_loop04.txt
GOTO语句,不建议用
DECLARE
x number;
BEGIN
x:=0;
<<repeat_loop>>
x:=x+1
DBMS_OUTPUT.PUT_LINE(x)
IF x<3 THEN
GOTO repeat_loop;
END IF;
SQL>save c:\plsql_loop05.txt
异常处理
DUP_VAL_ON_INDEX 向有唯一约束的表中插入重复行
NO_DATA_FOUND 在一个SELECT INTO语句中无返回值
TOO_MANY_ROWS SELECT INTO 语句返回多行
VALUE_ERROR 一个算法、转换、截断或大小约束发生错误
ZERO_DIVIDE 发生被零除
SQL>DECLARE
test varchar2(10)
BEGIN
SELECT name INTO test FROM deptment WHERE id='tt';
DBMS_OUTPUT.PUT_LINE(test);
END;
/
未查找到数据,系统异常
SQL>DECLARE
test varchar2(10)
BEGIN
SELECT name INTO test FROM deptment WHERE id='tt';
DBMS_OUTPUT.PUT_LINE(test);
EXCEPTION
WHEN NO_DATA_FOUND THEN 给定异常处理
DBMS_OUTPUT.PUTLINE('没有找到数据!')
END;
/
SQL>DECLARE
tname varchar2(10);
e exception;
BEGIN
SELECT name INTO tname FROM deptment WHERE id='01'
IF tname<>'B部门' THEN
RAISE e;
END IF;
DBMS_OUTPUT.PUT_LINE(tname);
EXCEPTION
WHEN e THEN
DBMS_OUTPUT.PUT_LINE('错误,不是需要的B部门!');
END;
/
复合变量
SQL>DECLARE
TYPE myrecord is RECORD(
id varchar2(10),
name varchar2(10));
real_record myrecord;
BEGIN
SELECT emp_id,emp_name INTO real_record FROM emp WHERE emp_id='001';
DBMS_OUTPUT.PUT_LINE(real_record.id||','||real_record.name);
END;
/
SQL>DESC emp;
SQL>EDIT
SQL>DECLARE
TYPE myrecord is RECORD(
id emp.eid%TYPE,与表中的字段类型一致
name varchar2(10));
real_record myrecord;
BEGIN
SELECT emp_id,emp_name INTO real_record FROM emp WHERE emp_id='001';
DBMS_OUTPUT.PUT_LINE(real_record.id||','||real_record.name);
END;
/
SQL>DECLARE
myrec emp%ROWTYPE;复合类型的子类型与表中字段相同
BEGIN
SELECT * INTO myrec FROM emp WHERE emp_id='001';
DBMS_OUTPUT.PUT_LINE(myrec.eid||','||myrec.ename||','||myrec.sex);
END;
/
五 游标
SQL>DECLARE
CURSOR mycur IS
SELECT * FROM books;
myrecord books%ROWTYPE;
BEGIN
OPEN mycur;打开游标
FETCH mycur INTO myrecord;把游标记录放到结果集中
WHILE mycur%FOUND LOOP 如果游标记录不为空,将记录循环显示出
DBMS_OUTPUT.PUT_LINE(myrecord.books_id||','||myrecord.books_name);
FETCH mycur INTO myrecords;把游标记录放到结果集中,游标进了一步
END LOOP;
CLOSE mycur;
END;
/
SQL>DECLARE
CURSOR cur_para(id varchar2) IS
SELECT books_name FROM books WHERE books_id=id;
t_name books.books_name%TYPE;
BEGIN
OPEN cur_para('0001');
LOOP
FETCH cur_para INTO t_name;
EXIT WHEN cur_para%NOTFOUND;当游标中的记录不存在时
END LOOP;
CLOSE cur_para;
END;
/
SQL>DECLARE
CURSOR cur_para(id varchar2) IS
SELECT books_name FROM books WHERE books_id=id;
BEGIN
DBMS_OUTPUT.PUT_LINE('******结果集为:******')
FOR cur IN cur_para('0001') LOOP 显示books_id等于'0001'的记录
DBMS_OUTPUT.PUT_LINE(cur.books_name);
END LOOP;
END;
/
SQL>DECLARE
t_name books.books_name%TYPE;
CURSOR cur(id varchar2) IS
SELECT books_name FROM books WHERE books_id=id;
BEGIN
IF cur%ISOPEN THEN 判断游标是否打开了
DBMS_OUTPUT.PUT_LINE('游标已经被打开!');
ELSE
OPEN cur('0003'); 如果没有打开,打开book_id等于'0003'的记录
END IF;
FETCH cur INTO t_name;
CLOSE cur;
DBMS_OUTPUT.PUT_LINE(t_name);
END;
/
SQL>DECLARE
t_name varchar2(10);
CURSOR mycur IS
SELECT name FROM deptment;
BEGIN
OPEN mycur;
LOOP
FETCH mycur INTO t_name;
EXIT WHEN mycur%NOTFOUND OR mycur%NOTFOUND IS NULL;
DBMS_OUTPUT.PUT_LINE('游标mycur的ROWCOUNT是:'||mycur%ROWCOUNT);用于游标的统计
END LOOP;
CLOSE mycur;
END;
/
游标参数
%FOUND
%ISOPEN
%NOTFOUND
%ROWCOUNT
利用游标来修改数据
SQL>DECLARE
CURSOR cur IS
SELECT name FROM deptment FOR UPDATE;
text varchar2(10);
BEGIN
OPEN cur;
FETCH cur INTO text;
WHILE cur%FOUND LOOP
UPDATE deptment SET name=name||'_t' WHERE CURRENT OF cur;
FETCH cur INTO text;
END LOOP;
CLOSE cur;
END;
/
隐式游标声明
SQL>BEGIN
FOR cur IN(SELECT name FROM deptment) LOOP
DBMS_OUTPUT.PUT_LINE(cur.name);
END LOOP;
END;
/
数据量大的时候不建议使用游标
PL/SQL高级应用存储过程
SQL>CREATE OR REPLACE PROCEDURE myproc (id IN varchar2)
IS
name varchar2(10);
BEGIN
SELECT books_name INTO name FROM books WHERE books_id=id;
DBMS_OUTPUT.PUT_LINE(name);
END myproc;
/
IN 表示是输入参数
OUT 表示是输出参数
查询创建的过程编译错误
SQL>SHOW ERRORS PROCEDURE myproc;
用存储过程执行
SQL>DECLARE
tid varchar2(10);
BEGIN
tid:='0001';
myproc(tid);
END;
/
用执行语句执行
SQL>EXECUTE myproc('0001');
SQL>CREATE OR REPLACE PROCEDURE myproc2(id IN varchar2,
name OUT varchar2)
IS
BEGIN
SELECT books_name INTO name FROM books WHERE books_id=id;
END;
/
SQL>DECLARE
tid varchar2(10);
tname varchar2(10);
BEGIN
tid:='0001';
myproc2(tid,tname);
六 视图
SQL>CREATE OR REPLACE VIEW myview
AS
SELECT * FROM books;
SQL>SELECT * FROM myview;
SQL>INSERT INTO myview(books_id) VALUES('0008')
SQL>CREATE OR REPLACE VIEW myview
AS
SELECT * FROM books WHERE price>30
SQL>INSERT INTO myview VALUES('0009','ABCDE',23.5,'AA')
SQL>CREATE OR REPLACE VIEW myview
AS
SELECT * FROM books WHERE price>30
WITH CHECK OPTION 检查在插入时price>30不能插入数据,只对视图起作用
SQL>SELECT * FROM deptment;
SQL>SELECT eid,ename,sex,d.id,d.name FROM emp e,deptment d
WHERE
e.id=d.id;
SQL>CREATE OR REPLACE VIEW v_emp_dept
AS
SELECT eid,ename,sex,d.id,d.name FROM emp e,deptment d
WHERE
e.id=d.id;
SQL>INSERT INTO v_emp_dept VALUES('007','ABC','33','TT');
如果组成视图的基表两个,两个以上,不允许同时对两个和两个以上的表更新
SQL>CREATE OR REPLACE VIEW v_read
AS
SELECT eid,ename FROM emp
WITH READ ONLY; 设置视图为只读
DISTINCT情况下也是不能更新的,因为是多条,这样的视图也是不能更新的
SQL>DESC dba_views 查看所有视图
SQL>DESC user_views 查看当前用户的视图
SQL>SELECT text FROM user_views WHERE view_name='V_READ';
用数据字典来查看视图的语法,语句
同义词 DBA创建公用同义词 一般用户创建专有同义词
SQL>SELECT user FROM dual;
SQL>SELECT * FROM dept;
SQL>SELECT * FROM scott.dept;
创建同义词
SQL>CREATE SYNONYM dept FOR scott.dept;
SQL>connect tt/tt11
SQL>SELECT * FROM dept;
SQL>connect sys/test1234 as sysdba
SQL>DROP SYNONYM dept
创建公有同义词
SQL>CREATE PUBLIC SYNONYM dept FOR scott.dept;
SQL>SELECT * FROM dept;
SQL>connect tt/tt11
SQL>SELECT * FROM dept;
SQL>DESC dba_synonyms查看同义词的数据字典
SQL>CONNECT tt/tt11
SQL>CREATE SYNONYM dep FOR scott.dept;
SQL>SELECT * FROM dept;
SQL>desc user_synonyms
SQL>SELECT synonym_name,table_name,table_owner FROM
user_synonyms;
序列
创建序列
SQL>CREATE SEQUENCE myseq
START WITH 1 开始处为1
INCREMENT BY 1 增长为1
ORDER 默认排序 从小到大
NOCYCLE; 不循环
查询下一个序列的值
SQL>SELECT myseq.NEXTVAL FROM dual;序列为1
SQL>SELECT myseq.NEXTVAL FROM dual;序列为2
SQL>SELECT myseq.NEXTVAL FROM dual;序列为3
查看当前序列的值
SQL>SELECT myseq.CURRVAL FROM dual;必须写完NEXTVAL的查询,
才能查询CURRVAL
创建一个表
SQL>CREATE TABLE auto(a number,varchar2(10));
执行三条查询,当前插入的序列就从4开始
SQL>INSERT INTO auto VALUES(myseq.NEXTVAL,'dfd');序列为4
SQL>INSERT INTO auto VALUES(myseq.NEXTVAL,'dfd');序列为5
SQL>INSERT INTO auto VALUES(myseq.NEXTVAL,'dfd');序列为6
SQL>SELECT * FROM auto;
SQL>DESC dba_sequences 查看的序列的数据字典
SQL>SELECT sequence_name,sequence_owner FROM dba_sequence
WHERE sequence_owner='TT'
SQL>SELECT user FROM dual;查看当前登录用户名称
SQL>ALTER SEQUENCE myseq INCREMENT BY 3;更改序列增长为3
七 触发器
SQL>SELECT * FROM books;
SQL>DELETE FROM books WHERE books_id='0011'
提交
SQL>commit;
SQL>DELETE FROM books WHERE books_id='0010'
回滚
SQL>rollback;
SQL>DELETE FROM books WHERE books_id='00d10';
事务的特性:原子性、一致性、隔离性、永久性
SQL>SELECT * FROM emp;
SQL>SELECT * FROM deptment;
SQL>CREATE OR REPLACE TRIGGER del_deptid
AFTER DELETE ON deptment
FOR EACH ROW 行级触发器
BEGIN
DELETE FROM emp WHERE id=:old.id;一种特殊的方式,强记,逻辑表
END del_deptid;
/
SQL>DELETE FROM deptment WHERE id='01'
SQL>SELECT * FROM emp;
SQL>SELECT * FROM deptment;
SQL>CREATE OR REPLACE TRIGGER insert_dept
AFTER INSERT ON department
FOR EACH ROW
BEGIN
INSERT INTO emp(eid,ename,id) VALUES ('121','QWERT','new.id');一种特殊的方式,强记,逻辑表
END;
/
SQL>INSERT INTO deptment VALUES('77','GHJ');
SQL>SELECT * FROM emp;
OLd New
INSERT 无 有
DELETE 有 无
UPDATE 有 有
SQL>CREATE OR REPLACE TRIGGER update_dept
AFTER UPDATE ON deptment
FOR EACH ROW
BEGIN
UPDATE emp SET id=:new.id WHERE id=:old.id
END;
/
SQL>UPDATE department SET id='yy' WHERE id='01';
SQL>SELECT * FROM emp;
SQL>CREATE OR REPLACE TRIGGER books_delete
AFTER DELETE ON books
FOR EACH ROW
BEGIN
IF:old.book_id='0001' THEN
RAISE_APPLICATION_ERROR(-20000,'不允许删除!');
END IF;
END;
/
SQL>SELECT * FROM books;
SQL>DELETE FROM books WHERE books_id='0009'
SQL>DELETE FROM books WHERE books_id='0001'
触发器里不能写rollback,DBMS.OUTPUT_LINE
SQL>SELECT * FROM aa;
SQL>CREATE TABLE mylog(curr_user varchar2(100),curr_date,act char(1));
SQL>CREATE OR REPLACE TRIGGER dm1_aa
AFTER INSERT OR DELETE OR UPDATE ON aa
BEGIN
IF INSERTING THEN 语句级的触发器
INSERT INTO mylog VALUES(user,sysdate,'I')
ELSEIF DELETING THEN
INSERT INTO mylog VALUES(user,sysdate,'D')
ELSE
INSERT INTO mylog VALUES(user,sysdate,'U')
END IF;
END;
/
SQL>SELECT * FROM aa;
SQL>UPDATE aa SET a2='test' WHERE a1='cha';
SQL>SELECT * FROM aa;
SQL>DELETE FROM aa WHERE a2='dee';
SQL>INSERT INTO aa VALUES('tt','yy','uu')
SQL>SELECT * FROM mylog;
触发器日期
SQL>SELECT curr_user,TO_CHAR(curr_date,'yyyy-mm-dd' hh24:mi:ss')
D FROM mylog;
SQL>SELECT * FROM auto;
SQL>SELECT myseq.NEXTVAL FROM dual;
SQL>SELECT myseq.NEXTVAL FROM dual;
SQL>INSERT INTO auto VALUES(myseq.nextval,'SD');
SQL>SELECT * FROM auto;
SQL>CREATE OR REPLACE TRIGGER set_no
BEFORE INSERT ON auto
FOR EACH ROW
DECLARE
sn number(5);
BEGIN
SELECT myseq.nextval INTO sn FROM dual;
:NEW.a:=sn;用序列来代替插入的NEW.a的值
END;
/
SQL>INSERT INTO auto VALUE(21,'df');
SQL>INSERT INTO auto VALUE(2321,'ddtt');
SQL>SELECT * FROM auto;
替换触发器
SQL>INSERT INTO v_emp_dept VALUE('456','test','f','33','hg');
在ORACLE中替换触发器只能用在视图上,用于解决更新两个和两个以上的基表
SQL>CREATE OR REPLACE TRIGGER tr_v_e_d
INSTEAD OF INSERT ON v_emp_dept
FOR EACH ROW
BEGIN
INSERT INTO deptment VALUES(:new.id,:new.name);
INSERT INTO emp(eid,ename,sex,id) VALUES (:new.eid,:new.ename,
:new.sex,:new.id)
END;
/
SQL>INSERT INTO v_emp_dept VALUE('456','test','f','33','hg');
SQL>SELECT * FROM v_emp_dept;
八 安全管理
ORA_DBA Administrator
http://localhost:5500/em Oracle Manager System
创建用户 显示SQL
SQL> connect test/test1234
SQL> SELECT * FROM scott.dept;
SQL> connect sys/test1234 as sysdba
设置权限
SQL> GRANT SELECT ON scott.dept TO test;
改变连接方式
SQL> conn / as sysdba
改变默认表空间
SQL> ALTER USER test DEFAULT TABLESPACE tt;
SQL> ALTER USER test DEFAULT TABLESPACE users;
更改密码
SQL> ALTER USER test IDENFIFED BY test11;
SQL> conn test/test11
SQL> conn / as sysdba
锁定帐号
SQL> ALTER USER test ACCOUNT LOCK;
解除锁定
SQL> ALTER USER test ACCOUNT UNLOCK;
SQL> CREATE USER qqq IDENTIFIED BY qqq123
DEFAULT TABLESPACE tt;
SQL> connect qqq/qqq123
SQL> conn / as sysdba
SQL> GRAINT CONNECT TO qqq;
SQL> SELECT * FROM scott.dept;
SQL> GRANT SELECT ON scott.dept TO qqq;
SQL> conn / as sysdba
给予授权的权限
SQL> GRANT SELECT ON scott.dept TO test WITH GRANT OPTION
SQL> connect test/test11
SQL> GRANT SELECT ON scott.dept TO qqq;
SQL> GRANT INSERT ON scott.dept TO test WITH GRANT OPTION
包括INSERT、DELETE、UPDATE
SQL> GRANT ALL ON scott.dept TO test WITH GRANT OPTION
对过程进行授权
SQL> GRANT EXECUTE ON tt.proc01 TO test
SQL> conn test/test11
SQL> CREATE USER abc IDENTIFIED BY abc;
SQL> conn / as sysdba
创建用户的权限
SQL> GRANT CREATE USER TO test;
SQL> conn test/test11
SQL> DROP USER abc
SQL> conn / as sysdba
删除用户的权限
SQL> GRANT DROP USER TO test;
SQL> conn test/test11
SQL> DROP USER abc;
SQL> conn / as sysdba
SQL> GRANT CREATE USER TO test;
SQL> GRANT CREATE USER TO qqq;
对象授权
SQL> GRANT CREATE USER TO test WITH GRANT OPTION;
系统授权
SQL> GRANT CREATE USER TO test WITH ADMIN OPTION;
SQL> GRANT CREATE USER TO qqq;
SQL> conn qqq/qqq123;
SQL> CREATE USER ty IDENTFIED BY ty;
取消授权
SQL> REVOKE SELECT ON scott.dept FROM test;
SQL> REVOKE CREATE USER FROM test;
角色授权
创建角色
SQL> CREATE ROLE myrole;
分配角色
SQL> GRANT SELECT ON tt.emp TO myrole;
SQL> GRANT SELECT ON tt.deptment TO myrole;
SQL> connect test/test11
SQL> SELECT * FROM tt.emp;
SQL> conn / as sysdba
将角色给用户,或者说添加用户到角色
SQL> GRANT myrole TO test;
SQL> connect test/test11
SQL> SELECT * FROM tt.emp;
SQL> conn / as sysdba
SQL> GRANT myrole TO qqq;
SQL> connect qqq/qqq123
SQL> SELECT * FROM tt.emp;
ORACLE Enterprise Manager 概要文件 创建概要文件,授权给用户
九 表空间的管理
SQL> SELECT user FROM dual;
新建一个表空间
SQL> CREATE TABLESPACE tabs
DATAFILE 'C:\oracle\product\10.1.0\oradata\test\tabs.dbf'
SIZE 10M;
为用户设置默认表空间
SQL> ALTER USER test DEFAULT TABLESPACE tabs;
SQL> connect test/test11
SQL> CREATE TABLE tre(t char(10),re number);
SQL> conn / as sysdba
授予创建表空间的权限
SQL> GRANT UNLIMITED TABLESPACE,DBA TO test;
SQL> connect test/test11
SQL> CREATE TABLE tre(t char(10),re number);
创建一个表放到默认表空间中
SQL> CREATE TABLE ty(t char(10),y varchar2(10)) TABLESPACE TT;
十 表的管理
实体完整性,主键约束,域完整性是指插入数据不能大于类型的约束
SQL> SELECT * FROM emp;
SQL> INSERT INTO emp(eid,ename) VALUE ('001','test22');
建立主键约束
SQL> ALTER TABLE nn ADD CONSTRAINT pk_nn PRIMARY KEY(n1);
参照完整性,参照表需要被参照表的字段
SQL> SELECT * FROM nn;
SQL> CREATE TABLE mm(m1 char(10),m2 varchar2(10),n1 varchar2(10)).
SQL> INSERT INTO mm VALUE('avd','dd','gg');
SQL> SELECT * FROM mm;
SQL> ALTER TABLE mm ADD CONSTRAINT fk_mm FOREGIN KEY(n1)
REFERENCE nn(n1);
check约束
SQL> DESC emp
SQL> UPDATE emp SET sex='男' WHERE eid='001'
SQL> ALTER TABLE emp ADD CONSTRAINT ck_emp_sex CHECK(sex='男'
or sex='女');
SQL> DESC dba_constraints查看一个表的约束情况
查看一个表的具体的约束
SQL> SELECT constraint_name,constraint_type FROM user_constraints
WHERE table_name='EMP';
SQL> desc emp
索引,索引是建立在表字段上的
在表上的字段上建立索引
SQL> CREATE INDEX my_mm_idx ON mm(m1);
位图索引
SQL> SELECT * FROM emp;
SQL> CREATE bitmap INDEX bit_emp ON emp(sex);
唯一约束的索引
SQL> CREATE UNIQUE INDEX myidx ON mm(m2);
十一 SQL LOAD
SQL>exit
SQL>sqlldr
SQL>
记事本创建两个文件
1.数据文件
abc,xyz
def,qqq
fff,ggg
save as c:\loader.txt
2.控制文件
load data
infile 'c:\loader.txt'
append
into table mm(
m1 position(1:3) char,
m2 position(5:7) char)
save as c:\cont.ctl
SQL>sqlldr tt/tt11 control=c:\cont.ctldata=c:\loader.txt通过控制文件写入数据
SQL>sqlplus tt/tt11
SQL>SELECT * FROM mm;
load data
infile 'c:\loader.txt'
append
into table mm(
m1 lterminated by ",",
m2 char terminated by ",")如果不是固定长度,用","区分
SQL>sqlplus tt/tt11
SQL>SELECT * FROM mm;
十二 OEM的配置
Enterprise Manger 企业管理工具(IE登录方式)
sys SYSDBA方式登录
性能、管理、维护
十三 监听程序及服务的配置
TCP/IP原理 1521端口
windows管理 服务 ORACLE Listener
c:\>lsnrctl status 状态
c:\>lsnrctl start 打开
c:\>lsnrctl stop 关闭
c:\>lsnrctl start lisnt_name 指定名称打开
Net Manager ORACLE网络管理程序
添加 监听程序 如listener1 指定监听端口号如1522
新加一个数据库名称
c:\>lsnrctl start listener1
c:\oracle\product\10.1.0\Db_2\NETWORK\ADMIN\listener.ora 监听程序的配置文件
Net Configuration Assistant 用数据库管理助手配置监听程序
c:\oracle\product\10.1.0\Db_2\NETWORK\ADMIN\lnsnames.ora
SQL>connect tt/tt11@ora ora为刚刚配置的监听服务
SQL>SELECT * FROM emp
十四 数据库备份与恢复
C:\>exp tt/tt11@test
Enter array fetch buffer size:4096>5000
Export file:EXPDAT.DMP>c:\mybak.dmp
<1>E<ntire database>, <2>U<sers>, or <3>T<ables>: <2>U >deptment dept
EXP-00012:deptme?...is not a valid export mode
<1>E<ntire database>, <2>U<sers>, or <3>T<ables>: <2>U >t
Export table data <yes/no>: yes > yes
Compress extents <yes/no>: yes > yes
Export done in ZHS16GBK charater set and AL16UTF16 NCHAR character set
About to export specified tables via Conventional Path...
Table<T> or Partition<T:P> to be exported: <RETURN to quit> >
Export terminated successfully with warnings
详细导出
c:\>exp tt/tt11@test
>5000
>c:mybak.dmp
>yes
>
>t
>emp
恢复导入
c:\>sqlplus "tt/tt11";
SQL>SELECT * FROM CMP;
SQL>DELECT FROM emp;
SQL>COMMIT;
SQL>SELECT * FROM emp;
c:\>imp tt/tt11
>c:mybak.dmp
输入缓存区的大小>
依次选择yes or no
冷备份
SQL>shutdown immediate
选择oradata中的文件拷贝到备份目录下
SQL>startup mount
SQL>archive log list;查看归档日志
将数据库设置为日志归档方式
SQL>alter system set log_archive_start=true scope=spfile;
SQL>shutdown immediate;
评论
将数据库设置为日志归档方式
SQL>alter system set log_archive_start=true scope=spfile;
SQL>shutdown immediate;
SQL>startup mount;
SQL>alter database archivelog;
SQL>alter database open;
SQL>archive log list;
SQL>alter tablespace tt begin backup;
SQL>alter tablespace tt end backup;
SQL>alter system archivelog current;
SQL>alter system switch logfile;
SQL>alter system switch logfile;
SQL>shutdown immediate;
SQL>startup
SQL>select * from v$recover_file;
恢复
SQL>alter database datafile 6 offline drop;
SQL>alter database open;
SQL>SELECT * FROM tt.deptment;
SQL>RECOVER DATAFILE 6;
auto
SQL>ALTER DATABASE DATAFILE 6 ONLINEL;
SQL>SELECT * FROM tt.deptment
备份控制文件
SQL>shutdown immediate
备份oradata下的控制文件
SQL>@c:\create_ctl.txt用控制文件的脚本重新创建控制文件
SQL>select user from dual;
备份日志文件
SQL>recover database until cancel
SQL>alter database open resetlogs
发表评论
-
abc
2013-03-01 11:21 808http://blog.csdn.net/oypj2010/a ... -
视图查询慢
2012-10-15 23:41 1594我遇到过,单独查询视图很快,但是两个SQL语句查询同一个视图后 ... -
TRANSLATE函数
2012-09-08 23:53 1314TRANSLATE返回将from_string中的每个字符替换 ... -
ORACLE临时表
2012-09-08 09:18 1149CREATE GLOBAL TEMPORARY TABLE T ... -
Oracle正则表达式的用法
2012-09-05 22:26 1023l 方括号表达 ... -
Oracle正则表达式的用法
2012-09-05 22:26 1287l 方括号表达 ... -
Mysql coalesce() 函数认识和用法
2012-09-02 22:22 11153coalesce()解释:返回参数中的第一个非空表达式(从左向 ... -
ORACLE日期转换
2012-08-18 16:49 1330ORACLE中日期转换SELECT TO_CHAR(SYS ... -
本地索引和全局索引区别
2011-09-24 12:36 9947表可以按range,hash,list分区,表分区后,其上的索 ... -
将mysql非分区表转换为分区表
2011-09-22 23:54 1530查看表的分布状况 mysql> select count ... -
oracle中的sql%found sql%notfound和sql%rowcount
2011-01-05 22:15 1435当执行一条DML语句后,DML语句的结果保存在四个游标属性中, ... -
SQLCODE和SQLERRM
2011-01-05 22:09 1396Oracle内置函数SQLCODE和SQLERRM是 ... -
in|out|in out参数模式
2011-01-05 22:06 1409Oracle 过程中定义了in|out|in out3中参数模 ... -
oracle trunc & round区别
2010-12-29 22:59 2646一、Oracle中的Round和Trunc: 如同对数字进行 ... -
truncate与delete区别
2010-12-29 22:51 938区别: 1、在功能上,truncate是清空一个表的 ... -
CONNECT BY LEVEL 实现12月统计数据
2010-11-29 22:44 1076create table test(j varchar2(10 ... -
ORACLE 百万行数据查询优化
2010-11-13 14:15 11801.对查询进行优化,应尽量避免全表扫描,首先应考虑在 wher ... -
oracle10g中的wm_concat
2010-11-13 14:02 1104wmsys.wm_concat这个函数,它的作用是以',' ... -
Oracle中connect by...start with...的使用
2010-10-26 22:03 1074一、语法 大致写法:sel ... -
什么是ETL
2010-10-17 17:34 2323ETL即数据抽取(Extract)、转换(Transform) ...
相关推荐
Oracle10g学习笔记,Oracle10g学习笔记Oracle10g学习笔记Oracle10g学习笔记Oracle10g学习笔记Oracle10g学习笔记
### Oracle 10g知识点详解 #### 一、文件操作命令 在Oracle 10g中,可以通过一些特定的命令来进行文件的操作。 - **SAVE**: 用于保存数据到指定路径的文件。 - 示例:`SAVE C:\1.txt` 表示将数据保存到C盘根目录...
### Oracle 10g DBA 知识点详解 #### 一、Oracle 服务与启动命令 在 Oracle 10g 数据库管理中,服务名(Service Name)和系统标识符(System Identifier, SID)是两个重要的概念。服务名用于客户端连接到数据库...
### Oracle10g基础知识与管理要点 #### 一、数据库概览 在介绍Oracle10g之前,我们先简要回顾一下数据库的概念及其发展。数据库是长期存储在计算机内、有组织的、可共享的数据集合。它能有效地管理和处理大量的...
│ oracle10g权限与角色管理初学笔记.txt │ oracle10g的系统视图(sys、system).txt │ oracle10g系统管理之UNDO表空间 - lvhuiqing的专栏 - CSDN博客.mht │ oracle10g系统管理之序列 - lvhuiqing的专栏 - CSDN博客...
### Oracle 10g 新特性概览 #### 安装、服务器配置与数据库升级 - **安装新特性支持**:Oracle 10g 引入了一系列新的安装特性,旨在简化安装过程并提高效率。 - **性能增强的安装过程**:通过优化安装流程,提升...
《成功之路:Oracle 11g学习笔记》专为开发人员编写,先引导开发新手熟悉Oracle环境,然后进入数据库开发,并要掌握项目开发中的一些技巧。开发技巧展示是《成功之路:Oracle 11g学习笔记》的一大特色(这一点很值得...
在Red Hat Enterprise Linux (RHEL) 5 x86-64系统上通过命令行安装Oracle 10g是一项技术性很强的任务,涉及到多个步骤和系统配置。以下是一些关键的知识点: 1. **权限管理**: - 安装过程中,你需要切换到root...
Oracle 11g 是一款企业级的关系型数据库管理系统,它提供了高效的数据存储、管理和分析功能。在Linux环境下安装Oracle 11g涉及多个步骤,包括下载软件、创建用户和管理组、预先创建安装目录以及设置相应的权限和环境...
《成功之路Oracle11g学习笔记》是一本专为初学者设计的Oracle数据库学习资源,旨在帮助读者系统地掌握Oracle11g的基础知识。Oracle11g是Oracle公司推出的一个重要版本,它提供了许多增强的功能和优化,使得数据库...
该文档是李兴华针对oracle 11g 的课堂笔记,是pdf格式文本。。。。
很全的 韩顺平2011 玩转oracle 每个代码均经过测试 可行 回馈社会 2分
本学习笔记详细记录了作者在准备Oracle 11g OCP认证过程中的学习心得和实践经验,对于希望深入理解Oracle数据库管理和优化的读者来说,是一份宝贵的资料。 Oracle 11g包含了许多重要的特性和改进,例如: 1. **...
"Windows Server 2008 安装 Oracle 11g 详细笔记总结" 本文将详细介绍如何在 Windows Server 2008 上安装 Oracle 11g,包括安装前的准备工作、安装过程、安装后的配置和基本操作。 一、安装前的准备工作 在安装 ...
这篇学习笔记将带你深入理解Oracle11g的核心概念和技术,帮助你踏上数据库管理的成功之路。 首先,Oracle11g的基础部分涵盖了数据库安装、配置与管理。在安装过程中,你需要了解如何选择合适的安装选项,如企业版或...
有关oracle数据库基础学习OCP课程的基础051的课程笔记
资源名称:成功之路:Oracle 11g学习笔记内容简介:本书专为开发人员编写,先引导开发新手熟悉Oracle环境,然后进入数据库开发,并要掌握项目开发中的一些技巧。开发技巧展示是本书的一大特色(这一点很值得资深的...