老王是荆职百获食堂的采购员,每天买白菜50斤,土豆30斤,茄子30斤,豆角50斤,采购完都会记录到下面的Vegetable 表中,请你用学到的Oracle知识帮帮老王算算帐。
编号 |
白菜单价 |
土豆单价 |
茄子单价 |
豆角单价 |
日期 |
001 |
0.35 |
0.5 |
0.5 |
1.2 |
2017/11/10 |
002 |
0.4 |
0.6 |
0.5 |
1.3 |
2017/11/11 |
003 |
0.3 |
0.5 |
0.6 |
1.3 |
2017/11/12 |
004 |
0.5 |
0.5 |
0.5 |
1.35 |
2017/11/13 |
005 |
0.45 |
0.6 |
0.6 |
1.4 |
2017/11/14 |
006 |
0.45 |
0.5 |
0.55 |
1.2 |
2017/11/15 |
007 |
0.5 |
0.6 |
0.5 |
1.25 |
2017/11/16 |
1 请你计算一下老王每天的采购支出以及这周的采购支出
2 计算那天花钱最多
3 求出豆角一周的平均价格
system 123456 create user wang identified by wang123456; grant create table to wang; grant create session to wang; grant resource to wang; grant connect to wang; grant create sequence to wang; conn wang/wang123456; create sequence myseq; --使用序列 select myseq.nextval 序号 from dual; select myseq.nextval 序号 from dual; select myseq.nextval 序号 from dual; select myseq.nextval 序号 from dual; select myseq.currval 当前序号 from dual; select myseq.currval 当前序号 from dual; select myseq.nextval 序号 from dual; select myseq.currval 当前序号 from dual; select sequence_name,max_value,min_value, increment_by,last_number from SEQ where sequence_name=upper('myseq'); select to_char (myseq.nextval,'000') 序列号 from dual; --循环序列3 5 7 9 11 create sequence seq2 increment by 2 maxvalue 11 minvalue 2 cycle nocache; select seq2.nextval 序号 from dual; select seq2.nextval 序号 from dual; select seq2.nextval 序号 from dual; select seq2.nextval 序号 from dual; select seq2.currval 当前序号 from dual; select seq2.currval 当前序号 from dual; select seq2.nextval 序号 from dual; select seq2.currval 当前序号 from dual; create sequence seq3 increment by 1 start with 190325114710914 nocycle; select 'wxA'||seq3.nextval 快递单号 from dual; select 'wxA'||seq3.nextval 快递单号 from dual; select 'wxA'||seq3.nextval 快递单号 from dual; select 'wxA'||seq3.nextval 快递单号 from dual; create table vegetable ( 编号 number(3)primary key, 白菜 number(3,2) not null, 土豆 number(3,2) not null, 茄子 number(3,2) not null, 豆角 number(3,2) not null, 日期 date ); insert into vegetable select 001,0.35,0.5,0.5,1.2,'10-11月-17'from dual union select 002,0.4,0.6,0.5,1.3,'11-11月-17'from dual union select 003,0.3,0.5,0.6,1.3,'12-11月-17'from dual union select 004,0.5,0.5,0.5,1.35,'13-11月-17'from dual union select 005,0.45,0.6,0.6,1.4,'14-11月-17'from dual union select 006,0.45,0.5,0.55,1.2,'15-11月-17'from dual union select 007,0.5,0.6,0.5,1.25,'16-11月-17'from dual; --用序列插入 create sequence seq4; alter table vegetable modify 编号 char(10); insert into vegetable values(to_char(seq4.nextval,'000'),0.35,0.5,0.5,1.2,'10-11月-17'); insert into vegetable values(to_char(seq4.nextval,'000'),0.4,0.6,0.5,1.3,'11-11月-17'); insert into vegetable values(to_char(seq4.nextval,'000'),0.3,0.5,0.6,1.3,'12-11月-17'); insert into vegetable values(to_char(seq4.nextval,'000'),0.5,0.5,0.5,1.35,'13-11月-17'); insert into vegetable values(to_char(seq4.nextval,'000'),0.45,0.6,0.6,1.4,'14-11月-17'); insert into vegetable values(to_char(seq4.nextval,'000'),0.45,0.5,0.55,1.2,'15-11月-17'); insert into vegetable values(to_char(seq4.nextval,'000'),0.5,0.6,0.5,1.25,'16-11月-17'); select * vegetable; select 日期,白菜*50+土豆*30+茄子*30+豆角*50 总消费 from vegetable; --视图的概念:把你的查询结果做一个封装叫做视图 conn system/123456 grant create view to wang; conn wang/wang123456; create view xiaofei_view as select 日期,白菜*50+土豆*30+茄子*30+豆角*50 总消费 from vegetable; select * from xiaofei_view; select sum(总消费) from xiaofei_view; select 日期 from xiaofei_view where 总消费=(select max(总消费)from xiaofei_view); select avg(豆角) from vegetable; 作业 create table disney ( id number primary key, data varchar2(10) ); create sequence id_seq5; create or replace trigger bifer_disney_id_pk beFORe insert on disney FOR each row BEGIN SELECT id_seq5.nextval into :new.id FROM dual; END; / insert into disney(data) VALUES('TOM'); insert into disney(id,data) VALUES(6,'Jerry'); select * from Disney; 作业二 conn system/123456; create user xiaoxue identified by xiaoxue123; grant create table to xiaoxue; grant create session to xiaoxue; grant resource to xiaoxue; grant connect to xiaoxue; grant create sequence to xiaoxue; conn xiaoxue/xiaoxue123; create sequence myseq; conn system/123456; grant create view to xiaoxue; conn xiaoxue/xiaoxue123; create sequence seq6 increment by 1 start with 1000421 nocycle; select 'wxA'||seq3.nextval 快递单号 from dual; select 'wxA'||seq3.nextval 快递单号 from dual; select 'wxA'||seq3.nextval 快递单号 from dual; select 'wxA'||seq3.nextval 快递单号 from dual; create table chanping ( 产品编号 number(10), 产品名称 varchar2(8), 质检员 number(5), 生产日期 date );
1 求出king 的下属(mgr)并封装为视图 2 求出oracle公司的总人数(count)并封装为视图 3 求出工资大于1000并封装为视图 4 求出工号(empno),工资(sal)名字(ename)并封装为视图 5 求出每个人的姓名(ename),部门编号(deptno) 并封装为视图。 conn system/123456; grant create view to scott; conn scott/tiger; create view emp_mgr_view as select * from emp where mgr=7839; create view emp_count_view as select count(ename) 总人数 from emp ; create view emp_sal_1000_view as select * from emp where sal>1000; create view emp_empno_sal_ename_view as select empno,sal,ename from emp ; create view emp_ename_deptno_view as select ename,deptno from emp ;
用户名Scott 密码tiger select * from emp; --展示表结构 desc emp; --字段查询 select ename,sal from emp; select ename,empno from emp; select ename,hiredate ,sal,comm from emp; select ename,job,sal from emp; select ename,mgr,deptno from emp; --更改语句 --给所有人涨10%工资 select ename ,sal from emp; update emp set sal=sal*1.1; --领导说不能涨 rollback; select ename,sal from emp; --换种方案涨工资 --大于2000的涨20%,小于2000的涨10% update emp set sal=sal*1.2 where sal>2000; update emp set sal=sal*1.1 where sal<2000; --永久生效,不能更改 commit; --distinct 去除重复列 select ename ,job from emp; select distinct job from emp; select distinct deptno from emp; select distinct mgr from emp; --% 通配符 --查询首字母为a的员工信息 select * from emp where ename like 'A%'; --查询第二个字母为a的员工信息 select * from emp where ename like '_A%'; --查询第三个字母为a的员工信息 select * from emp where ename like '__A%'; --查询第四个字母为a 的员工信息 select * from emp where ename like '___A%'; --查询有a的员工 select * from emp where ename like '%A%'; --查询没有a的员工姓名 select ename from emp where ename not like '%A%'; --员工编号empno出现9的员工 select * from emp where empno like '&9&'; --上司编号mgr 出现8的姓名 select * from emp where mgr like '&8&'; --员工姓名ename出现s的员工的姓名 select * from emp where ename like '&s&'; --处理空值null select ename ,comm from emp where comm is not null; select ename,comm from emp where comm is null; select ename 姓名 ,nvl(comm,100)+sal*13 年薪 from emp; --p144,6.46-6.54 select deptno,count(*),sum(sal) from emp GROUP BY deptno; select job ,count(*),avg(sal) from emp where deptno=20 GROUP BY job having avg(sal)>1000; select * from emp,dept; select * from emp e,dept d where e.deptno=d.deptno; select empno ,sal ,s.* from emp e, salgrade s where sal between s.losal and s.hisal; select e.empno,e.ename,e.mgr ,b.empno,b.ename from emp e,emp b where e.mgr =b.empno; select * from emp e left join dept d on e.deptno =d.deptno; select * from emp e right join dept d on e.deptno =d.deptno; select * from emp e full join dept d on e.deptno=d.deptno; --1平均工资,最低工资,最高工资 --job分类 平均工资,最低工资,最高工资 select * deptno,count(*),sum(sal) from emp group by deptno; select job,count(*),avg(sal) from emp group by job; select job,count(*),min(sal) from emp group by job; select job,count(*),max(sal) from emp group by job; --having的用法 select job ,count(*),avg(sal) from emp group by job having avg(sal)>2000; --多表连接 select distinct e2.ename 上司的名字 from emp e1,emp e2 where e1.mgr=e2.mgr;
1 查询 经理人的工资 2 查询 津贴比工资高的员工 3 查询 和当前月份和入职月份相同的员工的工资 4 查询 入职年份 是1982年的员工 5 查询 每个部门的平均工资同时按照部门编号进行排序 6 查询 每个工种(job)的最低工资同时按照工种进行排序、 7 查询员工表(emp) 按照入职日期进行desc排序 8 查询 大于ALLEN这名员工的工资 1 select sal from emp where job='MANAGER'; select sal from emp where job=upper('manager'); 2 select ename from emp where comm>sal; 3 select ename,sal from emp where to_char(sysdate,'MM')=to_char(HIREDATE,'MM'); select ename,sal from emp where to_char(sysdate,'dd')=to_char(HIREDATE,'dd'); 4 select ename,empno from emp where to_char(HIREDATE,'yyyy')='1982'; 5 select deptno,avg(sal) from emp group by deptno ; 6 select job ,avg(sal) from emp group by job; 7 select * from emp order by hiredate desc; 8 select sal from emp where ename=upper('allen'); select sal from emp where ename='ALLEN'; select ename,sal from emp where sal>(select sal from emp where ename='ALLEN');
小雪是友达乳业有限公司的DBA ,由于刚入职所以很多工作还不熟悉,现在公司需要一些数据 请你帮帮她。公司采用的是oracle数据库
- 创建小雪账号并且登录(小雪工号是531 密码123)
- 新建产品表
- 创建产品编号型序列
- 插入表数据
- 生成产品编号和生成日期视图
- 查询出过期的酸奶编号(保质期为7天)
数据表如下
产品编号 |
产品名称 |
质检员 |
生产日期 |
YD1000421 |
酸奶 |
510 |
2019年3月19日 |
YD1000422 |
酸奶 |
510 |
2019年3月19日 |
YD1000423 |
酸奶 |
510 |
2019年3月19日 |
YD1000424 |
酸奶 |
510 |
2019年3月19日 |
YD1000425 |
酸奶 |
510 |
2019年3月19日 |
YD1000426 |
酸奶 |
510 |
2019年3月19日 |
YD1000427 |
酸奶 |
499 |
2019年3月20日 |
YD1000428 |
酸奶 |
499 |
2019年3月20日 |
YD1000429 |
酸奶 |
499 |
2019年3月20日 |
YD1000430 |
酸奶 |
499 |
2019年3月20日 |
YD1000431 |
酸奶 |
499 |
2019年3月21日 |
YD1000432 |
酸奶 |
499 |
2019年3月21日 |
YD1000433 |
酸奶 |
499 |
2019年3月21日 |
YD1000434 |
酸奶 |
499 |
2019年3月21日 |
YD1000435 |
酸奶 |
499 |
2019年3月21日 |
YD1000436 |
酸奶 |
510 |
2019年3月22日 |
YD1000437 |
酸奶 |
510 |
2019年3月22日 |
YD1000438 |
酸奶 |
510 |
2019年3月22日 |
YD1000439 |
酸奶 |
510 |
2019年3月22日 |
YD1000440 |
酸奶 |
510 |
2019年3月22日 |
YD1000441 |
酸奶 |
510 |
2019年3月22日 |
YD1000442 |
酸奶 |
510 |
2019年3月23日 |
YD1000443 |
酸奶 |
510 |
2019年3月23日 |
YD1000444 |
酸奶 |
510 |
2019年3月23日 |
YD1000445 |
酸奶 |
510 |
2019年3月23日 |
YD1000446 |
酸奶 |
510 |
2019年3月23日 |
YD1000447 |
酸奶 |
510 |
2019年3月23日 |
YD1000448 |
酸奶 |
499 |
2019年3月24日 |
YD1000449 |
酸奶 |
499 |
2019年3月24日 |
YD1000450 |
酸奶 |
499 |
2019年3月24日 |
YD1000451 |
酸奶 |
499 |
2019年3月24日 |
用户名:system 密码123456 create user wangmin identified by wangmin123456; grant create session to wangmin; grant create table to wangmin; grant resource to wangmin; grant connect to wangmin; conn wangmin/wangmin123456; --创建student表--学号--姓名--电话号码--年龄--生日--邮箱 --length,求字段长度 create table student ( id number(8)primary key, name varchar2(20) not null, tel number(11) unique check(length(tel)=11), age number(3) check(age<150), both date, email varchar2(20) not null ); --删除表 drop table student; --逐条插入 insert into student values (18424186,'旭辉',18888888888,18,'01-1月-01','666@126.com'); insert into student values (18424846,'家乐','13777777777',101,'01-1月-20','110@qq.com'); insert into student values (1842424,'静静','13888888888',17,'02-2月-02','555@qq.com'); insert into student values (1842425,'汪敏','18288888888',20,'01-2月-02','888@qq.com'); --查询表 select * from student; --删除单行数据 delete from student where id=18424186; delete from student where id=18424846; delete from student where id=1842424; delete from student where id=1842425; --更改表里面电话的类型 alter table student modify tel char(11); --测试非空 insert into student (id,tel)values (188888,13222222222); create table library ( bookID number(4) primary key, bookName varchar2(40) not null, author varchar2(10) , price number(9,2) check(price<100), publishDate date, ISBN varchar2(20) UNIQUE ); 用户名:system 密码123456 create user wangmin identified by wangmin123456; grant create session to wangmin; grant create table to wangmin; grant resource to wangmin; grant connect to wangmin; conn wangmin/wangmin123456; --创建student表--学号--姓名--电话号码--年龄--生日--邮箱 --length,求字段长度 create table student ( id number(8)primary key, name varchar2(20) not null, tel number(11) unique check(length(tel)=11), age number(3) check(age<150), both date, email varchar2(20) not null ); --删除表 drop table student; --逐条插入 insert into student values (18424186,'苏旭辉',18888888888,18,'01-1月-01','666@126.com'); insert into student values (18424846,'汪家乐','13777777777',101,'01-1月-20','110@qq.com'); insert into student values (1842424,'静静','13888888888',17,'02-2月-02','555@qq.com'); insert into student values (1842425,'汪敏','18288888888',20,'01-2月-02','888@qq.com'); --查询表 select * from student; --删除单行数据 delete from student where id=18424186; delete from student where id=18424846; delete from student where id=1842424; delete from student where id=1842425; --更改表里面电话的类型 alter table student modify tel char(11); --测试非空 insert into student (id,tel)values (188888,13222222222); --事物处理(函数) max min avg 用Scott登录 select max (sal) 最大值 from emp; select min (sal) 最小值 from emp; select avg (sal) 平均值 from emp; 怎么求那些人的工资高于平均值? select ename,sal from emp; select ename from emp where(sal>(select min(sal)from emp)); 正负一指标法如果他工资低于平均工资那么这个人的指标为-1如果他的工资低于平均工资 那么他的指标为1 select ename 姓名 ,sign(sal-(select avg(sal) from emp)) 指标 from emp; sum 求和 select sum (sal) from emp; desc xxx;表结构 create table vegetable ( id number(3)primary key, bc number(3,2) not null, td number(3,2) not null, qz number(3,2) not null, dj number(3,2) not null, da date ); insert into vegetable select 001,0.35,0.5,0.5,1.2,'10-11月-17'from dual union select 002,0.4,0.6,0.5,1.3,'11-11月-17'from dual union select 003,0.3,0.5,0.6,1.3,'12-11月-17'from dual union select 004,0.5,0.5,0.5,1.35,'13-11月-17'from dual union select 005,0.45,0.6,0.6,1.4,'14-11月-17'from dual union select 006,0.45,0.5,0.55,1.2,'15-11月-17'from dual union select 007,0.5,0.6,0.5,1.25,'16-11月-17'from dual; 事务处理 (函数) max 最大值 min 最小值 avg 平均值 重新打开SQLPLUS 用户名 : scott 口令 :tiger select max(sal) 最大值 from emp ; select min(sal) 最小值 from emp; select avg(sal) 平均值 from emp; 下面一个问题 怎么求哪些人的工资高于平均值? select ename,sal from emp; select ename from emp where (sal>(select min(sal) from emp)); 正负一指标法 如果他的工资低于平均工资,那么这个人的指标为-1 如果他的工资高于平均工资,那么这个人的指标为1 select ename 姓名, sign(sal-(select avg(sal) from emp)) 指标 from emp; sum 求和 select sum(sal) from emp; 事务处理 (函数) max 最大值 min 最小值 avg 平均值 重新打开SQLPLUS 用户名 : scott 口令 :tiger select max(sal) 最大值 from emp ; select min(sal) 最小值 from emp; select avg(sal) 平均值 from emp; 下面一个问题 怎么求哪些人的工资高于平均值? select ename,sal from emp; select ename from emp where (sal>(select min(sal) from emp)); 正负一指标法 如果他的工资低于平均工资,那么这个人的指标为-1 如果他的工资高于平均工资,那么这个人的指标为1 select ename 姓名, sign(sal-(select avg(sal) from emp)) 指标 from emp; sum 求和 select sum(sal) from emp;
日期函数 select sysdate from dual; select to_char(sysdate,'YYYY-MM-DD') from dual; select to_char(sysdate,'YYYY-MM-DD HH:MI:SS') from dual; select '今天是开心的日子,时间为'||to_char(sysdate,'YYYY-MM-DD HH:MI:SS') from dual; -- 我活了多少月 select months_between(sysdate,'20-8月-90') from dual; select last_day(sysdate) from dual; select next_day(sysdate,'星期三') from dual; --时间戳 --常用的处理数据的内容 select count(*) from emp where sal>=3000; select count(*) from emp where sal>2000; select count(*) from emp where sal>=3000 and sal>2000; select count(*) from emp where sal<=3000 and sal>2000; select count(*) from emp where sal in(2000,3000) ; select count(*) from emp where sal not in(2000,3000);
标签:11,题目,函数,sal,0.5,查询,emp,dual,select From: https://www.cnblogs.com/bky-wang/p/18125044