数据库概念
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
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