当前位置:Gxlcms > 数据库问题 > oracle基础

oracle基础

时间:2021-07-01 10:21:17 帮助过:2人阅读

create table emp(
empno number(4),
ename varchar2(10),
job varchar2(9),
mgr number(4),
hiredate date,
sal  number(7,2),
comm number(7,2),
deptno number(2)
)
select * from emp
drop table emp
insert into emp values(7369,‘SMITH‘,‘CLERK‘,7902,‘17-12月-80‘,800,null,20)
insert into emp values(7499,‘JONES‘,‘MANAGER‘,7839,‘02-4月-81‘,2975,NULL,30)
insert into emp values(7788,‘SCOTT‘,‘ANALYST‘,7566,‘19-4月-87‘,3000,NULL,20)
insert into emp values(7839,‘KING‘,‘PRESIDNET‘,NULL,‘17-11月-81‘,5000,NULL,30)
insert into emp values(7521,‘WARD‘,‘SALESMAN‘,7698,‘22-2月-81‘,1250,500,30)
delete from emp where job=‘salesman‘
/*查询如果为空,按照0运算*/
select empno,ename,sal,sal*12,comm,sal*12+nvl(comm,0) from emp
/*查询奖金为null的员工*/
select * from emp where comm is null
/*别名sa*/
select empno as "员工号",ename "姓名",sal 月薪,sal*12,comm,sal*12+nvl(comm,0)
from emp
/*去重操作*/
select distinct deptno from emp
/*连接符*/
select ‘hello‘ ||‘world‘ 字符串 from dual
select ‘你‘||‘好‘ 问候 from dual
/*寻找名字为king的员工*/
select * from emp where ename=‘KING‘
/*查询所有*/
select *from emp
/*查询入职日期是*/
select * from emp where hiredate =‘17-12月-80‘
/*查询薪水在1000~2000的员工*/
select * from emp where sal between 800 and 1600
/*查询名字s打头的*/
select * from emp where ename like ‘S%‘
/*查询名字是四个子的*/
select * from emp where ename like ‘____‘
/*查询名字中包含下划线的*/
select * from emp where ename like ‘%\_%‘
/*对工资进行升序*/
select * from emp order by sal*12 asc
select sal*12 from emp order by 1 desc
/*大小写转换*/
select lower(‘GAGAGA‘)转小写,upper(‘agagagaga‘)转大写,initcap(‘hellworld ‘) 首字母大写 from dual 
/*截取字母*/
select substr(‘hellowrld‘,2)子串 from dual 
/*查找位置*/
select instr(‘hellowrld‘,‘w‘) 位置 from dual
/*日期函数*/ 
select to_char(sysdate,‘yyyy-mm-dd‘) from dual
/*多行函数*/
select sum(sal) from emp
/*人数*/
select count(*) from emp
/*group by */
select deptno ,avg(sal)
from emp 
group by deptno
/*having */

select deptno from emp group by deptno 
having avg(sal) >2000

  新问题:oracle 如何插入海量数据?

  

-- 我的思路是:
 
-- Step 1: 将1T左右的文本数据分解成 100 个文本文件,并按顺序命名
--         例如:tb001.txt、tb002.txt、tb003.txt、...、tb100.txt,
--         并存放到5个(或更多)不同的磁盘中(这样并行导入的时候磁盘瓶颈相对较小)!
 
-- Step 2: 在数据库中创建 5个(或更多)表空间,创建 100个名为 tb001、tb002、tb003、...、tb100的表,且平均分配到这5个表空间(其表的字段结构跟将要导入的目标表的字段结构一样)
 
-- Step 3:用数据字典生成导入语句(控制文件及要导入的口令:
-- 每个控制文件类似如下(共100个,所以:得用数据字典生成):
 
load data
infile "tb001.txt"
append into table tb001
fields terminated by ‘,‘
(col1,
col2,
col3,
...,
colN
)
 
-- 导入口令类似如下(共100条口令,可以加个并行 执行的参数或同时执行多个口令):
sqlldr userName/password control=tb001.ctl log=D:\your_path\tb001.log bad=D:\your_path\tb001.bad errors=1000
 
-- 最后:100个表的数据插入目标表(可以先将目标表的并行度加大,希望目标表是分区表更好,且先合理安排各分区表的数据文件的位置,以尽量避免IO瓶颈)
 
insert into target_table select * from tb001;
insert into target_table select * from tb002;
...
insert into target_table select * from tb100;

  数据的完整性?

    数据库完整性(Database Integrity)是指数据库中数据的正确性和相容性。数据库完整性由各种各样的完整性约束来保证,因此可以说数据库完整性设计就是数据库完整性约束的设计。
 什么是数据库的回滚?
    rollback命令
  

oracle基础

标签:

人气教程排行