真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Java37:數(shù)據(jù)庫(kù)(Oracle)

DB2

站在用戶的角度思考問題,與客戶深入溝通,找到羅山網(wǎng)站設(shè)計(jì)與羅山網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:網(wǎng)站制作、成都做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名注冊(cè)、網(wǎng)頁(yè)空間、企業(yè)郵箱。業(yè)務(wù)覆蓋羅山地區(qū)。

Oracle

Infomix

MySQL

Sybase

SQLServer

1 什么是數(shù)據(jù)庫(kù)

    數(shù)據(jù)需要持久保存

    (磁盤文件)

 數(shù)據(jù)庫(kù)(數(shù)據(jù)庫(kù)管理系統(tǒng))是個(gè)軟件

    安全,可靠,高效

 

 數(shù)據(jù)庫(kù)服務(wù)器,數(shù)據(jù)中心

 關(guān)系型數(shù)據(jù)庫(kù)

    用表來存儲(chǔ)數(shù)據(jù)的數(shù)據(jù)庫(kù)

 SQL 通用的關(guān)系型數(shù)據(jù)庫(kù)的操作語言

 不同數(shù)據(jù)庫(kù)之間SQL有一定的差異

 NOSQL Not only SQL

    芒果DB......

   

T-SQL

PLSQL

  SQL 中的分類

    DDL(Data Definition Language) 數(shù)據(jù)定義語言

        create;drop...

    DML(Data Maniplation Language)數(shù)據(jù)操作語言

        insert;delete;update...

    TCL(Transaction Control Language)事物控制語言

        begin transaction;commit;rollback....

    DQL(Data Query Language) 數(shù)據(jù)查詢語言

        select...

    DCL(Data Control Language)數(shù)據(jù)控制語言

        grant;revoke...

 

 安裝Oracle(DBA/OP)

    創(chuàng)建庫(kù)(DBA/OP) 

    創(chuàng)建用戶(DBA/OP)

     登陸數(shù)據(jù)庫(kù)(RD)

      訪問數(shù)據(jù)庫(kù)(RD)

文檔

表名,

字段名 ,類型 ,說明

create 語句創(chuàng)建表, 指定表明 表有幾列,列名,每個(gè)列的類型

類型:

數(shù)字 number(m) 不能超過m

    number(m,n) 一共m位,小數(shù)占n位

字符串 varchar2(m) 不能超過m

    (可變長(zhǎng)的字符串2版本)

日期 date

    有默認(rèn)格式 可以修改

    在插入日期時(shí)必須要符合這個(gè)格式

    對(duì)于日期可以使用to_date函數(shù)(但是保存在表中的數(shù)據(jù)還是系統(tǒng)設(shè)置的格式)

    第一個(gè)參數(shù)自己定義的格式

    to_date('2016-10-10','yyyy-mm-dd')

    第二個(gè)參數(shù)指明自定義格式

    

CREATE TABLE table_name 
    (column_name column_type);

//創(chuàng)建表
create table emp(id number(10),
          name varchar2(50),
          hire_date date,
          salary number(8,2));
//刪除表
DROP TABLE tablename;                
drop table emp;
//查看表的結(jié)構(gòu)(只能看表的結(jié)構(gòu),不能看數(shù)據(jù))
DESC tablename;
desc emp

//給表添加行
插入式可以指定為null
沒有插入的列就為null 除非有默認(rèn)值
INSERT INTO tablename(
    column_name,column_name,column_name)
    values
    (xxx,xxx,xxx,xxx);

insert into emp(id,name,hire_date,salary)values(101,'lmdtx',to_date('2016-10-10','yyyy-mm-dd'),123123.12);
OR
insert into emp values (101,'lmdtx',to_date('2016-10-10','yyyy-mm-dd'),123123.12);

//修改表中的某些行 where 是根據(jù)具體的條件來
UPDATE table_name SET field1=new-value1;
UPDATE table_name SET field1=new-value1, field2=new-value2[WHERE Clause]
update emp set salary=200 where id=101;

刪除表中行
DELETE FROM tablename;
DELETE FROM table_name [WHERE Clause];
delete from emp where id=101;


SELECT * FROM tablename;
SELECT * FROM tablename [WHERE Clause];
select * from emp;
select * from emp where salary>100;
select name,salary from emp where salary>100;

oracle 字符操作:

    varchar和varchar2 低版本還有區(qū)別高版本一樣的

    char 和 varchar2的區(qū)別:

        char 是定長(zhǎng)  char(20)  無論用多少都是20空間

                =》指的是存儲(chǔ)空間

        varchar2是可變長(zhǎng) varchar2(20) 按照實(shí)際的給空間

                默認(rèn)是存儲(chǔ)20個(gè)英文字符的空間

    length()

    varchar2 中文:

        一個(gè)中文占用幾個(gè)字符要看你使用的編碼 

        oracle 不是用的Unicode

        在設(shè)計(jì)表的時(shí)候要注意  一般是中文長(zhǎng)度 *3        

查看oracle 的字符編碼 userenv('language')

        

select userenv('language') from dual;

dual表 無實(shí)際意義,就是偽表給我們用一些函數(shù)使用的

    nvarchar2 類型  是幾個(gè)字符就是幾個(gè)字符 和編碼無關(guān)

char 和varchar2的最大長(zhǎng)度

char 2000個(gè)

varchar2 4000個(gè)

 

字符串的連接 ||  或者用 conncat(m,n)函數(shù)

'aa'||'bb'

create table class(
    xing nvarchar2(50),
    ming nvarchar2(50)
);

insert into class values('張','三');
insert into class vlaues('steve','steve')
select xing||ming from class;
select xing||'.'||ming from class;
select concat(xing,ming) from class;
select concat(concat(xing,'.'), ming) from class;

trim 去掉前后空格trim(String);

ltrim 左邊空格

rtrim 右邊空格

lpad 在左邊填充字符到指定長(zhǎng)度 lpad(String,50) 默認(rèn)是空格

rpad 在右邊填充字符到指定長(zhǎng)度rpad(String,50,'*')

lower 小寫lower(String)

upper 大寫

initcap 首字母大寫

length 求長(zhǎng)度

substr 截取字符串 substr(String,起始位置)  取到結(jié)尾

            substr(String,起始位置,取多少個(gè))

            substr(String,-20) 從后往前20個(gè)

    從1 開始

instr 在一個(gè)字符串中查找字符串  

返回第一次找到的位置    instr(String1,String2) 在String1 中查找String2

從1開始         instr(String1,String2,5) 在String1 中查找String2 從第5個(gè)開始找 

           instr(String1,String,5,2)在String1 中查找String2從第5個(gè)開始找到的第2個(gè)

create table emp(id number(10),
          name varchar2(50),
          hire_date date,
          salary number(8,2));
desc emp;

insert into emp(id,name,hire_date,salary)values(101,'lmdtx',to_date('2016-10-10','yyyy-mm-dd'),123123.12);

select *from emp;

select * from emp where id=102;

select name,salary from emp where salary>1000;

update emp set salary=100 where id=102;

update emp set salary=3000 where id=1011;

update emp set salary=99999 where id>2000;

update emp set salary=99999999999 where id=101;

delete  from emp where id = 010;

delete  from emp where id = 101;

drop table emp;

create table INFO_COST(
  ID number(11) primary key not null,
  COST_DESC VARCHAR2(200),
  BASE_DURATION number(11),
  BASE_COSR number(11,2),
  UNIT_COST number(11,2));
  
insert into INFO_COST(ID,COST_DESC,base_duration,base_cosr,unit_cost
)values(1,'包20小時(shí)',20,2.45,0.30);
  
insert into INFO_COST(ID,COST_DESC,base_duration,base_cosr,unit_cost
)values(2,'包40小時(shí)',40,3.45,0.30);
  
insert into INFO_COST(ID,COST_DESC,base_duration,base_cosr,unit_cost
)values(3,'包100小時(shí)',100,4.45,0.30);

insert into INFO_COST(ID,COST_DESC,base_duration,base_cosr,unit_cost
)values(4,'包200小時(shí)',200,5.45,0.30);
  
insert into INFO_COST(ID,COST_DESC,base_duration,base_cosr,unit_cost
)values(5,'普通資費(fèi)',null,null,0.20);
  
insert into INFO_COST(ID,COST_DESC,base_duration,base_cosr,unit_cost
)values(6,'包月',null,10,null);
  
update INFO_COST set unit_cost= unit_cost+(unit_cost*10) where id<5;
  
delet from INFO_COST WHERE id=5;
  
select COST_DESC,unit_cost from INFO_COST;


create table foo_1(c1 char(5),c2 varchar2(5));
insert into foo_1 values('abc','abc');
select length(c1),length(c2) from foo_1;

create table foo_2(c1 varchar(6));
drop table foo_2;
insert into foo_2 values('你好');
select * from foo_2;
select userenv('language') from dual;
desc dual;


create table foo_3(c1 nvarchar2(2));
insert into foo_3 values('你好');

create table class(
    xing nvarchar2(50),
    ming nvarchar2(50)
);

insert into class values('張','三');
select xing||ming from class;
insert into class values('steve','steve')
select xing||ming from class;
select xing||'.'||ming from class;
select concat(xing,ming) from class;
select concat(concat(xing,'.'), ming) from class;

create table foo_4(c1 varchar(500));
drop table foo_4;
insert into foo_4 values('     the fortification in your pole. It is like a peek your wallet as the thief, 
when you are thinking how to spend several hard-won lepta, when you are wondering whether new money, it has laid background.
    Because of you, then at the heart of the most lax, alert, and most low     of    ');
    
select trim(c1) from foo_4;
select ltrim(c1) from foo_4;
select rtrim(c1) from foo_4;
select lower(c1) from foo_4;
select upper(c1) from foo_4;
select initcap(c1) from foo_4;
select lpad(c1,600) from foo_4;
select lpad(c1,600,'@') from foo_4;
select substr(c1,100) from foo_4;
select substr(c1,100,120) from foo_4;
select substr(c1,-20) from foo_4;
select instr(c1,'of') from foo_4;
select instr(c1,'of',224) from foo_4;
select instr(c1,'of',224,2) from foo_4;

Oracle 日期操作

1日期類型

date 年月日時(shí)分秒(基本都是人輸入)

timestamp 年月日時(shí)分秒(秒帶小數(shù)點(diǎn))(系統(tǒng)來 時(shí)間戳)

sysdate 系統(tǒng)時(shí)間

systimestamp 系統(tǒng)時(shí)間戳

select sysdate from dual;
select systimestamp from dual;

to_date 把一個(gè)字符串轉(zhuǎn)換為日期

select todate('201610-10','yyyy-mm-dd') from dual;

to_char 把時(shí)間轉(zhuǎn)換為指定的格式

select to_char(sysdate,'yyyy-mm-dd hh:mi:ss') from dual;
create table foo_5(d1 date);
insert into foo_5 values(to_date('2016/10/10 09:00:00','yyyy/mm/dd hh:mi:ss'));
insert into foo_5 values(sysdate);
select to_char(d1,'yyyy~mm~dd hh34:mi:ss') from foo_5;
select to_char(d1,'yyyy~mm~dd hh34:mi:ss') from foo_5 where d1>sysdate;

last_day 計(jì)算所在月的最后一天

months_between 一個(gè)日期和另一個(gè)日期差幾個(gè)月

least 一個(gè)日期和給定日期那一個(gè)時(shí)間更早

返回小的

greatest一個(gè)日期和給定日期那一個(gè)時(shí)間更近

返回大的

create table foo_6(birthday date);
insert into foo_6 values(to_date('1990/09/09','yyyy/mm/hh'));
insert into foo_6 values(to_date('1890/09/09','yyyy/mm/hh'));
insert into foo_6 values(to_date('2016/10/10','yyyy/mm/hh'));
select to_char(last_day(to_date('2016/10/10','yyyy/mm/dd')),'dd') from dual;
select months_between(sysdate, birthday)/12 from foo_6;
select to_char(least(birthday,to_date('2016/08/08','yyyy-mm-dd')),'yyyy-mm-dd') from foo_6;
select least (1, 3 ) from dual 
select to_char(greatest(birthday,to_date('2016/08/08','yyyy-mm-dd')),'yyyy-mm-dd') from foo_6;
select greatest (1, 3 ) from dual

round  對(duì)時(shí)分秒進(jìn)行舍入 24小時(shí)制 12點(diǎn)后 算明天

trunc    對(duì)時(shí)分秒直接去掉

select to_char(round(sysdate),'yyyy/mm/dd') from dual;
select to_char(trunc(sysdate),'yyyy/mm/dd') from dual;

用于從一個(gè)date或者interval類型中截取到特定的部分 

extract(year from 日期)

extract(MONTH from 日期) 

extract(DAY from 日期)

extract(HOUR from 日期)

extract(MINUTE from 日期)

extract(SECOND from 日期)

select extract(year from sysdate) from dual;
select extract(month from sysdate) from dual;
select extract(day from sysdate) from dual;
select extract(hour from systimestamp) from dual;
select extract(minute from systimestamp) from dual;
select extract(second from systimestamp) from dual;

create 

drop (很少用,必須少用)

alter (很少用,必須少用,在 create 的時(shí)候要考慮好)

create table foo_11(
    n1 number(20);
    c1 varchar(50);
    
);
insert into foo_11 values(1,'abc');
insert into foo_11 values(null,'bcd');
insert into foo_11 values(3,null);
select * from foo_11 where c1 is null;

null 相關(guān):

nvl

nvl(arg1,arg2)

如果arg1 為null 返回arg2

如果arg1不為null 返回arg1

nvl2(arg1,arg2,arg3)

如果arg1為null 返回arg3;

如果arg1不為null 返回arg2;

select nvl(c1,'空')from foo_11;
select nvl2(c1,'非空','空') from foo_11;

not null 約束

 指定某些列不能為null

create table foo_12(
    n1 number(20) not null;
    c1 varchar(20) not null;
);

number的舍入(先舍入,在看長(zhǎng)度  )

create  table  foo_13(
    n1 number(5),
    n2 number(5,2), //對(duì)多的小數(shù)位直接舍棄,整數(shù)位多報(bào)錯(cuò)
    n3 number(5,-1),//  倒數(shù) 變 0  抹掉零頭..先舍入,在看長(zhǎng)度  最后一個(gè)0不算
);

主鍵 

數(shù)據(jù)的唯一性

1創(chuàng)建主鍵

主鍵也是列(多列,聯(lián)合主鍵)

一般沒有業(yè)務(wù)含義

唯一標(biāo)識(shí)數(shù)據(jù)表中的某一行

必須有主鍵

類型組好是number

主鍵不為null

主鍵不能重復(fù)

constraint 主鍵約束名 primary key(主鍵列)

create table stu(
  stu_id number(11),
  stu_no number(8),
  stu_name varchar2(50),
  constraint stu_pk primary key(stu_id)
);

insert into stu values(123,100001,'張三');

修改表

刪除:

drop 刪除表

drop table stu;

delete刪除數(shù)據(jù) 可以恢復(fù),速度慢

delete table stu;
delete table str where stu_id=123;

truncate刪除表內(nèi)容不能恢復(fù),速度快

truncate table stu;

alter

添加列

如何增加not null列

    增加一個(gè)可以為空的列

    update設(shè)置值

    將該列改為not null

設(shè)置為主鍵

     更麻煩

修改列的屬性

刪除列

create table foo_22
  ( name varchar2(50)
  );
insert into foo_22 values('張三');
insert into foo_22 values('李四');
insert into foo_22 values('王五');
insert into foo_22 values('趙六');
insert into foo_22 values('齊七');

alter table foo_22 add
(
  salary number(8,2)
);

desc foo_22;

select * from foo_22;

alter table foo_22 modify(
  name varchar2(55) not null
);

desc foo_22;

alter table foo_22 add(
  s_id number(8)
);

desc foo_22;

update foo_22 set s_id=3 where name='張三';
update foo_22 set s_id=4 where name='李四';
update foo_22 set s_id=5 where name='王五';
update foo_22 set s_id=6 where name='趙六';
update foo_22 set s_id=7 where name='齊七';

select * from foo_22;

alter table foo_22 drop column s_id;

desc foo_22;
select * from foo_22;

拷貝數(shù)據(jù)

但是不能復(fù)制約束

create table emp2 
as select empno, ename, job,sal
from emp;

create table emp2 
as select empno, ename, job,sal
from emp where ename='lmdtx';

拷貝表結(jié)構(gòu)(在where 子句中 加上一個(gè)不成立的條件)但是不能復(fù)制約束

create table emp3
as select * from emp
where 1=2;

>= 

<= 

<> 不等于

AND 

OR

select * from emp2 where ename=''

a' or 'b'='b
注入***
select * from emp2 where ename='a' OR 'b'='b';

like 模糊查詢

 % 任意個(gè)字符

    M% 開頭是M的

    %M% 有M的

 _ 一個(gè)字符

select * from emp2 where ename like 'M%';
select * from emp2 where ename like '%A%';
select * from emp2 where ename like '_A%';

where 子句中的between ** and **

select salary from emp2 where salary between 1500 and 3000;

where 子句 中的 in 和 not in

select salary from emp2 where salary in (100,200,300);
 
select * from emp2 where ename='WARD' or ename='JAMES';

select * from emp2 where ename in ('WARD','JAMES');

select * from emp2 where ename not in ('WARD','JAMES');

where 子句判斷空值 is null 和 is not null

select * from emp2 where ename is null;
select * from emp2 where ename is not null;

where 中 子查詢

select * from emp2 where SAL=(select salary from emp2 where ename='WARD');
select *  from emp2 where ename in (select ename from emp2 where sal<1000 );

where 中 可以使用函數(shù)

select * from emp2 where length(ename)>4;

select 列的別名

    select 查詢的結(jié)果可以看成是一個(gè)邏輯上的一張表

select ename name from emp2;
        列名
             別名

select ename 姓名 from emp2;

去重 distinct

select distinct salary from emp2;

select 中可以使用函數(shù)

select ename||job from emp2;
select  ename||'='||job namejob from emp2;//在加上一個(gè)別名

聚合函數(shù)(聚集函數(shù))

count// null的不計(jì)數(shù)  統(tǒng)計(jì) 主鍵可以查有多行

select count(ename) from emp2;

min

select max(salary) from emp2;

max

select max(salary) from emp2;

sum

select sum(salary) from emp2;

avg

select avg(salary) from emp2;

排序

order by 對(duì)查詢的結(jié)果 可以根據(jù)某個(gè)或者幾個(gè)列進(jìn)行排序

    默認(rèn) asc 升序  

       desc 降序

  order by 后面也可以使用函數(shù)

    多個(gè)列

        先按照一個(gè)排序 再按照另一個(gè)拍 用

select ename,salary from emp2 where salary>1200 order by salary;

select ename,salary from emp2 where salary>1500 order by salary desc;

select ename,salary from emp2 where salary>1500 order by length(ename);

select ename,salary from emp2 orderby salary,length(ename);


文章名稱:Java37:數(shù)據(jù)庫(kù)(Oracle)
轉(zhuǎn)載源于:http://weahome.cn/article/gpopcg.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部