科帮网

登录/注册
您现在的位置:论坛 盖世程序员(我猜到了开头 却没有猜到结局) 盖世程序员 > Oracle增删查改 day01
总共48087条微博

动态微博

查看: 2259|回复: 0

Oracle增删查改 day01

[复制链接]

45

主题

5

听众

119

金钱

三袋弟子

该用户从未签到

跳转到指定楼层
楼主
发表于 2014-06-02 19:40:09 |只看该作者 |倒序浏览
数据库: DataBase,DB( |, E( ~. ^' c2 v0 l" H' g/ T- V
存放数据,管理数据的存储仓库。是有效组织在一起的数据集合。
$ j# o* A& U% {- k) Roracle是一种数据库软件。5 C, N4 B; G  G8 ~

' i3 `; x7 d7 R2 [7 V$ [Oracle  db2(IBM)  sybase(sybase)
8 y5 V5 b( n) I+ X. O. O4 f) N8 nsql server(MS)  mysql(Oracle)* W8 H  O8 i9 z9 I2 L
access
8 K- M# H  p1 h2 L, q
5 }  a& J2 ]5 ~' R/ C数据库管理系统(Database Management System): DBMS4 k9 i+ s0 T7 x. z2 @
; @: G" ]+ t5 p6 N1 F2 h' _
SQL:Structured Query Language
, ?8 h8 L2 d) Q' U8 S结构化查询语言:和数据库沟通的语言。! s; ?/ |0 J' Q  u; I/ ]
/ V! Y. K- b6 _# ~( v+ O+ m
DBA:Database Administrator 数据库管理员, X8 {5 l2 \' y& U  k
. R( E9 T8 z( D5 ^0 X' v7 x
Table:表:数据库的基本存储单元( K" k+ b( G: }
横向:行,row,record3 D" ^( t+ L* P) O2 I. i' K
纵向:列,column,field$ e0 O# D! p/ I& u

" E1 i0 W8 v# Z! B! q; h! \任务:把用户数据存入数据库的表中。
/ r* `  r0 C+ |3 ~5 U. y! Z5 _$ }# b实现:
' r' N' L' I3 a8 u. s! I6 U; k  Y1.建立一个连接
; v4 C  G  u% B. E& _  X8 i- k* \1)数据库所在的服务器的地址:192.168.0.26: ?- \2 N& }) A3 v; s. |; h5 m2 r
telnet 192.168.0.26
0 k2 H& J! a) N& Z( w服务器的帐号/密码:openlab/open123
. r5 [- M' e5 ^$ u, v, z2)数据库访问用户:
- i# W* U$ ~% j7 H( R+ c2 K( Bopenlab/open123
9 M3 l( z% l- a1 u! m数据库默认帐户:scott/tiger6 v+ T& D( S6 ]9 T
3)oracle数据库的连接工具:
$ Y* T, e+ d* F  h. x" O2 H8 ?) ~SQLPlus:Oracle数据库的客户端工具  ^; Y# [& U* L) P% g& z9 z
位于数据库的服务器上,192.168.0.26
/ M4 r& k' \7 S0 X0 o: N$ sqlplus openlab/open123
8 f8 k9 ^' H8 |5 a& P/ WSQL>
, ^, F4 @- K8 r" p# \' p" L6 ?如果提示SQL>表示登录成功
+ p6 S  e0 o2 y) y5 S0 y$ x6 `& H7 {2 q' z1 a% f
9 t' J+ Z! M: {! N5 U2 a
2.把数据表建立起来。0 \/ r) \6 Y. {& I
定义数据结构:$ g$ t8 h" j: u& V0 r7 a6 |+ s2 s
create table user_ning1(2 J7 a# u/ {! n  m5 l9 \0 x# E6 n
id number(4),8 c1 L. N6 E( I, f; B  R# Y
password char(4),8 c' p0 q& X2 u* _, H8 i9 y
name char(20),2 ?6 F8 _4 p! ^: x8 F
phone char(20),
$ ?, c' h0 Y- y  m7 ?email varchar2(50)( m  [& z- t% k) q2 K
);
7 e* O6 l5 C1 ^/ p提示Table Created. 表示表已成功创建。
5 \  `+ e& E8 y% c. Q; M3 \& ?
/ Y; s3 a( e. ?5 R数据类型:3 g. s8 T7 I( w: Z3 D
1)数字: & C0 W4 j6 B, e/ }
number(n),最长n位
% L/ K0 X7 v  ]3 b. Snumber(n,m),最长n位,小数点后m位( r' `# M) g0 j) ^4 ^! C/ ]& ?5 i
number(7,2): 99999.99
8 `6 D' I2 a) _& }) w( a# \0 M* `
* |% Y; _$ F# n) ^# d& ]2)字符串:  J& o( V, e* p/ {8 S. u
char: 定长字符串5 @% C6 ]/ F$ d4 Z- n1 O4 T4 G
varchar2:变长字符串
. s7 |6 ^' Y9 W" }% [  b9 G$ vchar(10)
/ J. p, \: [7 mvarchar2(10)
3 p6 s) l& B/ ?5 w$ I: j3)日期
0 i7 r9 |" m- W9 mdate
5 k; \4 ^" W5 g  G
& r: h7 o6 l9 @. b7 h, \% J清屏: clear scr/ c8 Y9 \0 W2 g

4 \9 E, C. {/ G2 y* t3.把用户数据存入数据表中。
# J  ?/ M' l' f2 G3 ]SQL>insert into user_ning15 `% |& |' w& f* {- u" ]
    values(1001,'1234','liucs','13600000000','liucs@sina.com');
9 r! O" r: u2 L! o5 t% T# c) a) {: p% Z1 z' j
insert into user_ning1 values(1004,'1234','liyi','98765432',/ U! G2 K0 n- v6 y
'liyi@sina.com');
: g3 h6 Z$ N8 t- l3 P% x! q5 M) |% U& M: U
错误语句:
, r( d5 z: B, }insert into user_ning1 values(1001,'1234','liucs','13600000000','my email', 25);
: ^+ I, t1 u, ]% z: X; c$ d1 ~' b! @, a$ C% M: X7 t
三种SQL语句:
& m1 K, g% k4 n3 N, t+ `# A1)create table...
$ i! d' q) Z5 S2) insert into...values...9 R2 v# x. M0 C# Y# F9 t
3) select ... from...3 y" {5 t' l9 A/ f/ w, V
8 }2 r0 Q/ |! e* w
SQLPlus命令:
1 Q6 ]7 f% T# x3 h% h设置每行数据的显示长度:
/ u5 y7 Z! Y; n3 xSQL>set linesize 2007 W9 \9 v: t8 O4 Q5 y7 U# s4 d8 O
设置列宽:10个字符, [5 A4 i4 {( p
SQL>column 列名 format a10
# H& J; W" `( X查看表结构:desc:describe 描述
1 C7 y; r8 U3 sSQL>desc user_ning1
% b/ K& r' b8 c; x, z8 D8 l3 U8 {2 L* U, `; p% X
规范数字宽度为4位:
/ O  i4 v1 S# Y1 c9 dSQL>column id format 9999
' g% i6 j+ N8 }, j( M3 U简写:9 L1 c7 j1 j' U/ _- R& C1 u" R4 @
SQL>col id for 9999
  F! ]7 t( b9 J! x7 ?% o
$ p2 D( }9 t3 \& N1 `--*表示查询全部列, A3 f; L% @! H" S3 ~) F
select * from user_ning1;
+ g1 t1 S; V) G. ~' g% s
; J& e' H8 k+ a5 \select name,email from user_ning1;
2 O0 z+ F$ p: M8 m, I* m1 ~% @+ ?- _. O5 N
--查找1001/1234考生的名字?; T* P6 Q0 v3 {7 D
select name, email from user_ning1, u: I- c$ `- c! c& B2 {0 X
where id = 1001
* g  K7 b4 y) P3 jand   password = '1234';9 Y# H) I3 R* S% K, }  N* R

; Y4 c( O8 B( B/ v* _& J' H( t数据准备:) g0 w9 R0 p* ]& Y9 e
1.表dept_ning:: z  D) ~& R- A" b9 J/ |$ y! ?
create table dept_ning(7 j" c5 H; |/ B  |: S$ D% K
deptno number(2),
9 X; r5 N# B3 a' x% qdname char(20),
( h7 p) g; n" H. ulocation char(20));! e: o$ ^& ^( h$ _% {8 `

8 c# B0 {, Y' }6 F! q) Adrop table dept_ning;
1 s# t  M2 X* J, t: F1 D5 r. o3 H" V  g6 j
增加数据:
) e- [' f. {2 x9 Ginsert into dept_ning values(10,'developer','beijing');  X% ?5 G6 C) B. e* s9 ~$ X  l7 G
insert into dept_ning values(20,'account','shanghai');+ Q2 e, W8 B& Q( I5 R5 x% k5 R
insert into dept_ning values(30,'sales','guangzhou');
/ _4 j% T8 {! [  Uinsert into dept_ning values(40,'operations','tianjin');. o3 e* s* C  n3 ?
. t7 \8 H9 P5 H8 P1 r3 t
commit;9 f$ N# r$ A  X9 C( N

! l1 u9 N; ^( R/ N1 G8 k" \select * from dept_XXX;
8 d. g) N8 F/ Q; K) @4 H0 ~3 [$ T. X& m. t* n9 @' X/ [
2.emp_ning8 L; ~) L$ }% r
create table emp_ning(
: N, P1 `( t( c1 |empno number(4),
& Q' a3 [1 H, R1 l0 }ename varchar2(20),/ W: x, M" c& m) @0 f  h
job varchar2(15),
/ A& _8 H. R6 G0 Y0 X) j, jsalary number(7,2),
* O9 V3 i  ~! \6 n8 v5 H# T( cbonus number(7,2),) x6 o8 B( Y" U6 ]# `, \7 q
hiredate date,2 E+ s/ b- ^' ^
mgr number(4),
- s1 }8 \8 i  @1 L& t9 X8 Fdeptno number(10)
9 Y! [0 O7 G6 B' |" x' K);
# F& L, `5 S7 I
1 x3 z- R: G3 Z+ }% Ninsert into emp_ning values(1001, '张无忌', 'Manager', 10000, 2000, '12-MAR-10', 1005, 10);
+ c/ D- H) f8 v* s; j0 iinsert into emp_ning values(1002, '刘苍松', 'Analyst', 8000, 1000,  '01-APR-11', 1001, 10);
+ q+ V& f% h0 G$ tinsert into emp_ning values(1003, '李翊', 'Analyst', 9000, 1000,  '11-APR-10', 1001, 10);
. c& q7 E# d* D& f4 I9 ^8 S7 pinsert into emp_ning values(1004, '郭芙蓉', 'Programmer', 5000, null, '01-JAN-11', 1001, 10); 6 I$ D: A/ u) W: K# @6 d
insert into emp_ning values(1005, '张三丰', 'President', 15000, null, '15-MAY-08', null, 20);
- h: `: [+ k+ minsert into emp_ning values(1006, '燕小六','Manager', 5000, 400, '01-FEB-09', 1005, 20);% \- h. M: M# N. V9 z; x
insert into emp_ning values(1007, '陆无双','clerk', 3000, 500, '01-FEB-09', 1006, 20);
$ i% v( T- L8 l' [3 winsert into emp_ning values(1008, '黄蓉','Manager', 5000, 500, '1-MAY-09', 1005, 30);! r& B1 m( V2 o: v
insert into emp_ning values(1009, '韦小宝','salesman', 4000, null, '20-FEB-09', 1008, 30);! I4 l* M0 j* u% n- H
insert into emp_ning values(1010, '郭靖','salesman', 4500, 500, '10-MAY-09', 1008, 30);5 F9 p; U0 J# ^( D9 B1 P

3 U7 _5 S0 X( R) n" G- Uset linesize 150: M2 W  |. Y  O  n+ U  t2 e7 t1 E
col empno for 9999! M3 G7 v& R  e+ M: I, x
col mgr for 9999/ p% I( T6 G# L( Y
col deptno for 99, ~8 f9 e: W0 s/ W- `
col salary for 99999.99
% y( J* s9 _9 R# d, m
) l* C  P5 Z- U! J% ?& {0 r) Nselect * from dept_ning;
# j; u) {( g% E% m. kselect * from emp_ning;
  \1 Y5 F8 p. ~5 l' z$ z* {
& x0 S3 t* k# |$ n: m一、学习查询语句。7 B- X7 C# Z7 @5 F# Y, e. J7 ^
1. 计算员工的名字、月薪和年薪?
; F' J6 N7 ~5 V7 Z3 I: Sselect ename, salary, 2 X; q5 u2 [9 z: c# x& v  f. v7 B5 |+ q
salary * 12 year_sal+ u! M9 i  L: _  N( D
from emp_ning;: q8 U- C' }5 x6 t$ j& X
. j% O6 H7 V2 q- O9 g
2.计算员工的月收入?9 L9 K' ^. t9 ^3 g/ B$ V
空值和任何数据做算数运算,结果为空(null), E2 h1 `' Y  A$ X) T' f# w
select ename, salary, bonus,# D3 j5 K5 |4 \) h. q- {2 m3 B
       salary + bonus month_sal; e  }( r7 N8 B$ U8 n% F0 Q
from emp_ning;
% p4 L7 N1 F. s) E4 \
0 }  p* k8 o$ ~8 n" lselect ename, salary, bonus,1 R! u- b( U2 W6 b# x3 J! B, n3 i: j
     salary + nvl(bonus, 0) month_sal
# P7 ^5 w8 u1 dfrom emp_ning;: p+ X! b2 |% H' H

: R! i, S  J' d9 |$ l( l8 hpublic double nvl(double d1, double d2){9 i7 R. Y0 S0 m2 Q5 Y/ e8 l0 M
        if (d1 != null)
! w0 t4 R) B9 o- g3 \! D9 Q            return d1;9 v+ |7 c: {+ _- L6 N' `5 M* W
        else
' q! M7 m! b+ b$ H- l5 z            return d2;       ( R: ~0 C# n0 g; U  [
}5 S  h' Q1 b1 h' s0 t
public String nvl(String s1,String s2)
# ]$ W9 v) a# \9 u2 U{. R3 q% U. E5 O% z8 y
        if (s1 != null)/ X# D- @* z- u' ?/ S5 ~5 U
                return s1;  }; m6 S1 i5 S9 x
        else
) s+ K+ Y+ y3 S                 return s2;' T, L* F: @  x9 u3 v/ u
}, }6 C2 s& Z+ j( d$ J, y
public Date nvl(Date d1, Date d2){
" f! C0 B4 s$ E  C8 Q/ q        return (d1 != null) ? d1 : d2;
4 l% J9 f2 D" q1 @7 F8 [}
  \9 R  h" b% W9 M& h& v* E8 T! n  l; |# l
insert into emp_ning& K1 k7 D7 j3 A/ C. q* J) D+ h
values(1011,'余泽成',null, null, null,6 \. E" b9 D5 u! w& Z. z
null, null, null);
* x$ [. {9 P+ `5 Q$ U" f简写为:$ r+ R, D, _  g' g) r
insert into emp_ning(empno, ename)' O1 g+ P; \6 k
values(1011,'余泽成');
) C2 z  J+ L2 Y9 [% T* q( y
$ E5 B$ u8 v2 T- i; ~9 M0 p' q$ g查询emp_ning表,如果没有职位,显示'no position',如果有职位,显示员工的职位。
2 ~& R4 \+ M9 {5 v  Y. S2 I" iselect ename, nvl(job,'no position')# N% F& x" D8 |
from emp_ning;! ^; W+ V5 E$ e* p1 Y& S' g# b4 ]

9 o8 ^) a/ z) ^' g查询emp_ning表,如果没有入职时间,显示2011年10月10日。如果有入职时间,显示。
9 d' O% m' s; j# z4 c4 Fselect ename, nvl(hiredate, '10-OCT-11') from emp_ning;/ D& T5 K  l- V. Y; E

1 z8 I$ v3 a/ z. R4 s: b$ Vnvl(bonus, 0)" e5 s  _5 u: h9 [: k( o
nvl(job, 'no position')
5 L( D+ |9 h0 |+ x. Dnvl(hiredate, '10-OCT-11'). ?4 ~; b+ [" i' z' W

' u, [0 G! x, x" _--复制表emp_YYY为emp_XXX
3 S/ U# U9 [: g+ qcreate table emp_XXX  C! F! s. h+ ~- M. @
as, g* o0 J2 }* q# o# i1 |
select * from emp_YYY;4 R8 W+ f1 ?% }
: }% R; f& R2 a5 J
3. 机构中有多少种职位?/ h5 z; z. n2 k" A0 I7 h1 y
select distinct job from emp_ning;9 f7 z" B/ a6 F+ ^" k; k

4 }, C( j' {! }: X  v% o8 I员工分布在哪些部门?
& B3 F. J3 W2 m+ b* _select distinct deptno from emp_ning;5 H/ _4 {. }! ^0 _* }
0 @( G/ b3 g) M3 A8 o
distinct必须/只能跟在select后边。
6 A& f* `$ _5 E% T, H
+ s" z  k7 F/ r( }, D. v4.薪水高于10000元的员工数据?- ?$ z; _- S! `0 X: ^2 v# l
select * from emp_ning2 W/ B# L4 j* U/ c0 f6 Y, [9 h
where salary > 10000;
/ h9 m0 ]3 |) |1 Q5 }# t( D
1 N: T/ \+ R7 u* b. C5.职位是Analyst的员工数据?' d) L+ M! q% G2 {2 g
select * from emp_ning
' G$ F! G6 J1 ^9 Qwhere job = 'Analyst';
2 \5 C( L: J, K% a4 M
0 z4 J7 s3 `. e% S$ Oanalyst  ANALYST  anaLyst
4 f) |, ]' W- u' Q6 ^
2 ~. e: Q6 S5 ^: Mselect * from emp_ning! }% }% V- p' I! {% z+ {4 x: j/ n9 L
where lower(job) = 'analyst';
* b2 K) P! |# Z9 F7 G6 f, W; c
4 J: I  r7 O4 |3 b8 F* C$ Dselect * from emp_ning
! j! P5 o/ [7 C, G( uwhere upper(job) = 'ANALYST';
+ a( a; ~7 C4 l& u- @
' y% j. h' |5 ~; t# g9 F; o--如果数据是analyst,查不出结果
& S4 a- K2 j4 q4 [# X--SQL语句大小写不敏感,数据大小写敏感
  ?, X- d3 w0 M& C5 D- G( a
3 ^+ M. O  ^2 q6.薪水大于5000并且小于10000的员工数据9 N1 M" ^6 i; T! }) L
" M! [9 H0 ?4 T9 j
select * from emp_ning
5 z# C8 w: m9 f5 m5 B, twhere salary >= 50009 d3 e) |# w  ^$ y+ j; q/ P
and salary <= 10000;
) [. a$ P$ w  Y) C; d; |. V0 f3 k8 B% i% x6 _
--在区间中:between 低值 and 高值
+ E4 ^4 A$ m3 G' U--闭区间:[低值,高值]+ q' z2 @; H2 T
select * from emp_ning% {7 O3 M! ?. k( |+ k
where salary between 5000 and 10000;
; Z2 m2 n% O' E  r, u) s8 n3 l# c9 r" D! h2 ?
入职时间在2011年的员工?  W# T0 S# b2 x, s6 V5 A
['01-JAN-11','31-DEC-11']
* R) e' e0 ]* r7 P! @/ f% Bselect * from emp_ning
3 w; b6 A. |. Ewhere hiredate between '01-JAN-11'
+ W( t* ?3 i8 m. }& Oand '31-DEC-11';+ J  W! g& P/ E5 T
0 O/ H! H4 d7 i2 B/ S: \
7.列出职位是Manager或者Analyst的员工- V6 m; o0 h  i1 Y, a

6 |: {) }' S! g9 N6 ~select * from emp_ning
# e6 s1 h2 s6 L! q. owhere job = 'Manager'* j( S- U% v) l, I
or    job = 'Analyst';
3 L* z, ], Z6 L+ ]2 _& Y--等价:in (list),在列表中。
* O! d4 Y9 E7 d, ]& ^$ p/ G! iselect * from emp_ning+ c; k# f( t  |6 c
where job in ('Manager','Analyst');
- c3 w# H6 R' [  n* }. l7 W+ z5 }4 g$ T6 q# O
8.列出职位中有sales字符的员工数据?
) g# `* A: s( _) Y: K" asalesman
7 W2 G/ p- V* U  b; |sales- K: T8 l# l7 L
before sales
( P# b4 Z0 O0 h9 {0 Q6 l7 J& z: fafter sales
, Y# m7 v- L4 O( \4 lbefore sales engineer
, _  r8 |; ?, b4 ]& v5 p% [+ X& w3 J1 y4 r1 g! u
--%: 0到多个字符,跟like配合,模糊匹配3 s8 [4 ?! ^% y% M/ u! q# i5 z
select * from emp_ning
$ x- X: t2 |% f+ x' O8 `9 mwhere job like '%sales%';. \3 X6 C% y3 U  g' N

4 J6 e0 p) H. W4 i$ ~9.查询哪些员工没有奖金?1 b3 y9 d( [5 Y" g% _
select * from emp_ning7 j8 q, w9 H% [
where bonus is null;+ M: p5 T  ~' M
8 v* T) I6 }3 E& w, C# ^! k
哪些员工有奖金?. p, d3 [; F* V5 ~& h4 y2 ?: h
select * from emp_ning
' i) |  ^6 y3 j6 |: ]. V8 awhere bonus is not null;* X- K6 }; N( n& M6 L. f1 i
( H: q6 `& P& S! Q& }, w
小结:7 W+ n7 T' k& r9 }: R# n$ V
1)create table ...
0 L5 d6 O9 b, l$ \8 [6 C. J  drop table 表名;
0 f0 q) u( x- \) z2)insert into 表名 values(...);* v0 I( D: T# e+ H: @" ?+ D$ ^! a8 a0 k
3)select distinct | * | 列名 | 算数表达式 | 别名% I2 U0 c) U! A9 m, u+ W
  from 表名
. K8 t) C0 a" O- t: ^' B0 \  where 条件1 or 条件2 and 条件3;$ ~7 L0 I3 L+ W' ?; t

$ U+ f8 Y+ P: T; W& ]- @) J> >= < <= between...and... in like* c6 x; @. U  {& ^5 T& {

  {' {/ k- C* M' ~

科帮网 1、本主题所有言论和图片纯属会员个人意见,与本社区立场无关
2、本站所有主题由该帖子作者发表,该帖子作者与科帮网享有帖子相关版权
3、其他单位或个人使用、转载或引用本文时必须同时征得该帖子作者和科帮网的同意
4、帖子作者须承担一切因本文发表而直接或间接导致的民事或刑事法律责任
5、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
6、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
7、科帮网管理员和版主有权不事先通知发贴者而删除本文


JAVA爱好者①群:JAVA爱好者① JAVA爱好者②群:JAVA爱好者② JAVA爱好者③ : JAVA爱好者③

快速回复
您需要登录后才可以回帖 登录 | 立即注册

   

关闭

站长推荐上一条 /1 下一条

发布主题 快速回复 返回列表 联系我们 官方QQ群 科帮网手机客户端
快速回复 返回顶部 返回列表