數據庫(mysql oracle)學習小結 一組:數據文件、控制文件、日志文件 oracle實例,它與數據庫的關系 oracle實例:實例就是數據庫啟動後分配的內存和建立的後台進程. 數據庫關閉後,物理上的文件還存在,但實例(分配的內存和建立的進程)就沒有了 數據庫:物理操作系統文件或磁盤(disk)的集合。 關系: 實例就是一組操作系統進程(或者是一個多線程的進程)以及一些內存。這些進程可以操作數據庫;而數據庫只是一個文件集合(包括數據文件、臨時文件、重做日志文件和控制文件)。 在任何時刻,一個實例只能有一組相關的文件(與一個數據庫關聯)。大多數情況下,反過來也成立:一個數據庫上只有一個實例對其進行操作。 不過,Oracle的真正應用集群(Real Application Clusters,RAC)是一個例外,這是Oracle提供的一個選項,允許在集群環境中的多台計算機上操作, 這樣就可以有多台實例同時裝載並打開一個數據庫(位於一組共享物理磁盤上)。 數據庫中的數據類型: 數字:mysql db2-----short integer long float double oracle--------number(30),number(30,3) 字符/字符串:char(10) varchar2(10) 日期和時間:date(年、月、日、小時、分鐘、秒) timestamp()(時間戳) oracle數據庫模式日期格式:03-3月-08 03-Mar-08 大對象(Characterlob/Binary lob) 主鍵應該具備的特征: 1.不能為null 2.主鍵必須唯一 where name like '\%' escape '\' 字符: upper lower initcap substr replace instr length lpad/rpad trim concat--------|| select substr(last_name,1,1)||lpad(last_name,sbustr(last_name,2,length(last_name)-1,'*') replace(last_name,substr(last_name,2,leghth(last_name)-2),lpad('',length(last_name)-2,'*') 日期: months_between add_months() next_day() last_day() 數字: round(2333,2) trunc mod round(sysdate,'month/year') 類型轉換的函數 to_char to_date to_number to_char(數字/日期,'fm') to_char(sysdate,'fmyyyy-mm-dd "fdfdfdfd" HH24:MI:SS am') to_char(234567,'fm99,999.00000') to_date('20-3月-58') to_date('[2008-02-08]','[yyyy-mm-dd]') RR 68 通用函數: nvl(commission_pct,0)----第一個表達式為null,返回第二個表達式的值,否則返回第一個表達式的值 nvl(commission_pct,1,0)--第一個表達式為null,返回第三個表達式的值,否則返回第二個表達式的值 nullif(last_name,first_name)--如果第一個表達式和第二個表達式的值相同,返回null,否則返回第一個表達式的值 decode() lpad('',round((salary*12+salary*12*nvl(commission_pct,0))/1000),'*') 多表的查詢兩種方法: 連接查詢 內連接:等值連接、非等值連接、自然連接。。。 外連接:左、右、全外連接 笛卡爾集----子集 select * from users u,orders o where u.id=o.user_id and ; select * from users u join orders o on u.id=o.user_id; cross join select a.dd,b.dd,c.dd from A a,B b,c c where a.pk=b.id and b.id=c.fk employee 1 A 500 2 B 660 3 c 1000 4 d 4000 level id name minsalary maxsalay 1 A級 5000 10000 2 B級 3000 5000 3 C級 1000 3000 4 D級 400 1000 A D級 B D級 C C級 D B級 select e.name,l.name from employee e,level l where e.salary between l.minsalary and l.maxsalary; 1 A 500 4 D級 400 1000 2 B 660 4 D級 400 1000 3 C 1000 3 C級 1000 3000 4 d 4000 2 B級 3000 5000 select * from users u left/right/full outer join orders o on u.id=o.user_id; Oracle寫外連接的簡便的方式: select * from users u,orders o where u.id(+)=o.user_id; select * from departments nature join loctions------兩個表的主外鍵必須同名,同類型 同名,類型不一致 select * from deparments join locations using(location_id); select * from departments d,locations l where d.location_id=l.locations_id; select e.last_name,e.job_id,d.department_name,e.salary,jg.grade_level from employees e,departments d,job_grades jg where e.department_id=d.department_id and e.salary between jg.minsalary and jg.maxsalary; USERS(id,name,birth) insert into users(id,birth) values(1,to_date('1998-01-01','fmyyyy-mm-dd')); insert into users values(1,'abc',to_date('1998-01-01','fmyyyy-mm-dd')); delete users where last_name='zhangsan'; SQL:結構化查詢語言,select DML:數據操縱語言:insert update delete DCL:數據控制語言:commit rollback。 事務:一組SQL語句的單元(DML語句為主) DDL:數據定義語言:create table users() insert into student values(3,'cc',100.99,null); DDL:數據定義語言 order by blueuser blueorder blue_user blue_order oa_user create table users( id number(10), name varchar2(40), age number(3) ); alter table users add constaint users_pk primary key (id); alter table users disable constraint users_pk; alter table users enable constraint users_pk; alter table users drop constraint users_pk; alter table users set unused (name,age); alter table users et unused column name; alter table users set unused column age; alter table users drop unused columns; drop table users; rename users to oa_users; truncate table users; select e.last_name,e.salary,e.department_id,d.mm from employees e,(select department_id dept_id,max(salary) mm from employees group by department_id) d where e.department_id=d.dept_id; select dfdfd from A a left outer join (select dfa) create or relpace view salary_vu is select e.last_name,d.department_name,e.salary,j.name from employees e,departments d,job_grades j where e.department_id=d.department_id and e.salary between j.minsalary and j.maxsalary; SELECT * FROM ( SELECT A.*, ROWNUM RN FROM (SELECT * FROM TABLE_NAME ) A WHERE ROWNUM <= to ) WHERE RN >= from