Oracle基础

/ROWNUM 是一个只有在实际返回数据时一个附加的数列/
select rownum, deptno , dname from dept;
insert into dept values(30,‘jack’,‘new york’);
insert into dept values(40,‘AAA’,‘new york’);
insert into dept values(50,‘VVV’,‘new york’);
insert into dept values(60,‘CCC’,‘new york’);

/创建一个表/

create table student(
stuName varchar2(10) NOT NULL,
stuNo char(6) not null,
stuAddress varchar2(50)
)

/修改数据库的字段属性/
alter table student modify(stuName varchar2(50));

/在数据表中添加字段/
alter table student add(stuPhone varchar(11))

/删除数据表中的某一字段/
alter table student drop(stuPhone);

/删除表/
drop table student;

/插入数据/
insert into student values(‘张三’,‘000001’,‘中国’);
insert into student values(‘李四’,‘000002’,‘中国’);
insert into student values(‘王五’,‘000003’,‘中国’);
insert into student values(‘张三’,‘000004’,‘中国’);
commit;

select * from student;

/去掉返回集中重复的数据 as 给字段起一个别名/
select distinct stuname as “学生姓名” from student

/* order by 根据某一个字段进行排序*/
select * from student order by stuName desc

/创建一个新表,但是这个表的数据来自student/
create table student2 as select * from student;

/* 选择指定的列来创建新表*/
create table student3 as select stuname,stuaddress from student2

create table student4 as select * from student where 1 = 2

select * from student4

select count(*) from student;
select count(1) from student;
select count(stuname) from student

select rowid, stuname, stuno from student group by rowid, stuname ,stuno having (count(stuname||stuno)<2)

drop from student where rowid not in
select max(rowid) from student group by stuname,stuno having(count(stuname||stuno)=1)

select max(rowid) from student group by stuname,stuno having(count(stuname||stuno)>=1)

/筛选出重复的数据/
select rowid,stuname from student where rowid not in(
select max(rowid) from student group by stuname,stuno having(count(stuname||stuno)>=1)
)

/删除重复数据,(学生姓名和学生编号相同的视为重复)/
delete from student where rowid not in(
select max(rowid) from student group by stuname,stuno having(count(stuname||stuno)>=1)
);
commit;

select * from student

create table tTest(
str char(5) not null
)

insert into tTest values(‘a’);
insert into tTest values(‘b’);
insert into tTest values(‘c’);
insert into tTest values(‘d’)

select * from ttest

/* 创建存档点*/
savepoint a;
insert into tTest values(‘e’)

/回退到某一个存档点/
rollback to a

/回退所有未提交的事务/
rollback;

commit;

select * from ttest
insert into tTest values(‘f’);
insert into tTest values(‘g’)
commit;

select rownum , str from ttest order by str desc

select str , rownum rn from(select str from ttest order by str desc) where rownum>1 and rownum<7

/* Orcale 分页*/
select * from(select str , rownum rn from(select str from ttest order by str desc)) where rn >=2 and rn<=6

/集合操作符/
/创建表/
create table tablea(
/* not null 不能为空*/
str char(2) not null
)

/创建表/
create table tableb(
str char(2) not null
)

/插入数据/
insert into tablea values(‘a’);
insert into tablea values(‘b’);
insert into tablea values(‘c’);
insert into tablea values(‘d’);
insert into tablea values(‘a’);
/提交事务/
commit;
select * from tablea;

insert into tableb values(‘a’);
insert into tableb values(‘b’);
insert into tableb values(‘b’);
insert into tableb values(‘d’);
insert into tableb values(‘e’);
commit;

/集合操作符/
/union 联合查询,返回的数据是不重复的数据 (会自动去除重复的数据,只保留一条)/
select str from tablea union select str from tableb ;
/union all 会将两个表中的所有的数据全部返回,包括重复的数据/
select str from tablea union all select str from tableb;

select str from tablea ;

/minus 返回第一个表中存在 但是第二个表中没有的数据 (第一个表指的是minus左边的表!!!)/
select str from tablea minus select str from tableb;

/intersect 返回两个表共有的数据/
select str from tablea intersect select str from tableb;

/连接操作符,将列名链接在一起/
select dname ||’-’|| address from dept

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值