Oracle_Q&A_04

2014-12-19作业

--1.在管理员权限下创建一个新用户,以你的名字命名,密码自定义

  1. CREATE
    USER LJL IDENTIFIED BY LJL;
  2. ALTER
    USER LJL IDENTIFIED BY LJL;
  3. ALTER
    USER LJL ACCOUNT UNLOCK;
  4. GRANT
    CONNECT,RESOURCE TO LJL;
  5. GRANT
    CREATE
    VIEW
    TO LJL;
  6. GRANT
    CREATE
    SESSION
    TO LJL;

--2.赋予新用户,连接,创建表,操作表等权限

  1. GRANT
    ALL
    ON scott.emp TO LJL;
  2. select * from dba_role_privs;
  3. select * from role_sys_privs;

--3.用新的用户连接数据库,用DDL语句创建以下表(字段名,数据类型自定义,但是要符合数据需求):

--1)客户信息表(ID,用户名,密码,邮箱,手机号码,地址)

  1. CREATE
    TABLE customer
  2. ???(
  3. ???cus_id NUMBER(6),
  4. ???cus_name VARCHAR2(20),
  5. ???cus_password VARCHAR(50),
  6. ???cus_email VARCHAR(50),
  7. ???cus_phone NUMBER(20),
  8. ???cus_address VARCHAR2(50)
  9. ???);
  10. ???select * from customer;
  11. ???--drop table customer;

--2)产品表(ID,产品名称,产品类别,尺寸,颜色,产地,价格)

  1. CREATE
    TABLE product
  2. ????(
  3. ????pro_id NUMBER(6),
  4. ????pro_name VARCHAR2(50),
  5. ????pro_category VARCHAR2(50),
  6. ????pro_size CHAR(10),
  7. ????pro_color CHAR(10),
  8. ????pro_orgin VARCHAR2(50),
  9. ????pro_price NUMBER(6)
  10. ????);
  11. ????select * from product;

--3)订单表(ID,订单编号,用户id,订单状态,支付状态,订单总额,创建时间)

  1. CREATE
    TABLE orders
  2. (
  3. ord_id NUMBER(6),
  4. cus_id NUMBER(6),
  5. ord_status CHAR(2),
  6. pay_status CHAR(2),
  7. ord_money NUMBER(6),
  8. ord_createtime DATE
  9. );
  10. select * from orders;

--4)订单明细表(ID,订单ID,产品ID,数量,金额,合计,创建时间,创建人)

  1. CREATE
    TABLE orderitems
  2. (
  3. ordit_id NUMBER(6),
  4. ord_id NUMBER(6),
  5. pro_id NUMBER(6),
  6. pro_num NUMBER(10),
  7. pro_price NUMBER(6),
  8. ordit_money NUMBER(6),
  9. ordit_createtime DATE,
  10. ordit_creator VARCHAR2(20)
  11. );
  12. select * from orderitems;

--4.给每个表加一个主键约束

  1. ALTER
    TABLE customer
  2. ??ADD
    CONSTRAINTS pk_customer_cusid PRIMARY
    KEY (cus_id);
  3. ?
  4. ??ALTER
    TABLE product
  5. ??ADD
    CONSTRAINTS pk_product_proid PRIMARY
    KEY (pro_id);
  6. ?
  7. ??ALTER
    TABLE orders
  8. ??ADD
    CONSTRAINTS pk_orders_ordid PRIMARY
    KEY (ord_id);
  9. ?
  10. ??ALTER
    TABLE orderitems
  11. ??ADD
    CONSTRAINTS pk_orderitems_cusid PRIMARY
    KEY (ordit_id);

--5.给客户表加一个邮箱的检查约束(邮箱中有@)

  1. ALTER
    TABLE customer
  2. ADD
    CONSTRAINTS cus_email_chk CHECK (cus_email like ‘%@%‘);

?

--6.给产品表的价格加一个不能是负数的检查约束

  1. ALTER
    TABLE product
  2. ?ADD
    CONSTRAINTS pro_price_chk CHECK (pro_price>0);

--7.给订单表加一个外键约束

  1. ????alter
    table orders
  2. ????add
    constraint ord_cusid_fk foreign
    key(cus_id)
  3. ????references customer (cus_id)
  4. ????on
    delete
    set
    null;--删除的时候子表外键字段置空
  5. --on delete cascade;--联级删除

--8.给订单明细表加两个外键约束

  1. alter
    table orderitems
  2. add
    constraint ordit_cusid_fk foreign
    key(ord_id)
  3. references orders (ord_id)
  4. on
    delete
    set
    null;--删除的时候子表外键字段置空
  5. ?
  6. alter
    table orderitems
  7. add
    constraint ordit_proid_fk foreign
    key(pro_id)
  8. references product (pro_id)
  9. on
    delete
    set
    null;--删除的时候子表外键字段置空

--9.创建一个四个序列,分别对应,客户表,产品表,订单表,订单明细表的主键

  1. CREATE SEQUENCE cus_seq;
  2. CREATE SEQUENCE pro_seq;
  3. CREATE SEQUENCE ord_seq;
  4. CREATE SEQUENCE ordit_seq;

--10.插入客户表几条测试数据(主键引用上面对应的序列值)

  1. INSERT
    INTO customer VALUES (cus_seq.nextval,‘tom‘,‘1234‘,‘[email protected]‘,12345677,‘中国‘);
  2. INSERT
    INTO customer VALUES (cus_seq.nextval,‘Alen‘,‘1234‘,‘[email protected]‘,12345677,‘美国‘);
  3. INSERT
    INTO customer VALUES (cus_seq.nextval,‘Jack‘,‘1234‘,‘[email protected]‘,12345677,‘加拿大‘);
  4. INSERT
    INTO customer VALUES (cus_seq.nextval,‘Mack‘,‘1234‘,‘[email protected]‘,12345677,‘英国‘);

--11.插入产品表几条测试数据(主键引用上面对应的序列值)

  1. INSERT
    INTO product VALUES (pro_seq.nextval,‘电脑‘,‘笔记本‘,‘14寸‘,‘黑色‘,‘中国‘,5000);
  2. INSERT
    INTO product VALUES (pro_seq.nextval,‘Iphone‘,‘手机‘,‘5.5寸‘,‘玫瑰金‘,‘美国‘,6320);
  3. INSERT
    INTO product VALUES (pro_seq.nextval,‘Ipad‘,‘平板‘,‘9寸‘,‘白色‘,‘中国‘,3500);
  4. INSERT
    INTO product VALUES (pro_seq.nextval,‘Itouch‘,‘手表‘,‘3.5寸‘,‘黑色‘,‘中国‘,250);

--12.插入订单表几条测试数据(主键引用上面对应的序列值)

  1. INSERT
    INTO orders VALUES (ord_seq.nextval,2,‘1‘,‘0‘,5000,sysdate);
  2. INSERT
    INTO orders VALUES (ord_seq.nextval,3,‘2‘,‘1‘,6320,sysdate);
  3. INSERT
    INTO orders VALUES (ord_seq.nextval,4,‘0‘,‘3‘,3500,sysdate);
  4. INSERT
    INTO orders VALUES (ord_seq.nextval,5,‘3‘,‘2‘,250,sysdate);
  5. ?select * from orders;

--13.插入订单明细表几条测试数据(主键引用上面对应的序列值)

  1. INSERT
    INTO orderitems VALUES (ordit_seq.nextval,3,2,1,5000,5000,sysdate,‘tom‘);
  2. INSERT
    INTO orderitems VALUES (ordit_seq.nextval,4,3,1,5000,5000,sysdate,‘tom‘);
  3. INSERT
    INTO orderitems VALUES (ordit_seq.nextval,5,4,1,5000,5000,sysdate,‘tom‘);
  4. INSERT
    INTO orderitems VALUES (ordit_seq.nextval,6,5,1,5000,5000,sysdate,‘tom‘);

--14.订单表是张业务量比较大的表,随着时间的推移,数据会越来越多,用户会经常用到用户id,和订单状态进行查选,现在需要优化查询速度,加一个索引

  1. create
    index index_ord on orders(cus_id,ord_status);

--15.当索引都不能满足性能要求的时候,需要拆分成当前表和历史表,把今年年初之前的所有数据全部迁移到历史表中

--并在把当前表年初之前的数据删除掉

  1. --这个没看懂
  2. ?CREATE
    TABLE ordersPAR
  3. ????(
  4. ????ord_id NUMBER(6),
  5. ????cus_id NUMBER(6),
  6. ????ord_status CHAR(2),
  7. ????pay_status CHAR(2),
  8. ????ord_money NUMBER(6),
  9. ????ord_createtime DATE
  10. ????)
  11. ????PARTITION BY RANGE (ord_createtime)
  12. ???(PARTITION historic VALUES LESS THAN (TO_DATE(‘2016-1-1‘, ‘YYYY-MM-DD‘)),
  13. ????PARTITION presently VALUES LESS THAN (TO_DATE(‘2016-12-31‘, ‘YYYY-MM-DD‘)))

--16.现在由于订单表分了当前表和历史表,但是用户想查两个表的数据,写一个集合语句查两个表中的数据

  1. select * from historic UNION
    select * from presently;

--17.用最高权限的管理员账号,授予SCOTT账号可以访问你刚刚建的用户下,客户信息表所有增删改查权限

  1. GRANT
    ALL
    ON LJL.customer TO scott;

Reference

LJDragon的作业

Oracle_Q&A_04

时间: 2024-10-07 13:17:02

Oracle_Q&A_04的相关文章

Oracle_Q&A_03

1.先导入SQL文件 执行语句查看表信息 select * from student;--学生信息--(stunum,stuname,classid)select * from class;--班级信息--(classid,classname,teacher(班主任))select * from scores;--成绩表--(scoresid,stunum,score,kcbh,kcmc,create_time)select * from course;--科目信息--(courseid,cou

Oracle_Q&A_02

Step02: Import SQL FILE Step02: QUESTION & ANSWER --1查询员工姓名和职位字数相等的员工 --2查询e_name以s结尾的员工(不用like) --3查询所有的员工的名字,截取ENAME的首字母,--拼接后面的,输出以下格式S.King --4查询所有的ENAME,把“S”换为“-”之后再输出 --5用户输入一个任意编号,查询此编号的员工 --6用户输入一个关键字,查询last_name包含此关键字的员工(不用LIKE) 执行另外一个SQL文件-

Oracle_Q&A_01

Step01: SHOW USER DESCRIPTION Step02:QUESTION & ANSWER --查询员工姓名和职位字数相等的员工 SELECT * from emp where length(ename)=length(job); --查询ename以s结尾的员工(不用like) SELECT * FROM emp where substr(ename,-1)='S'; --查询所有的员工的名字,截取ENAME的首字母, SELECT substr(ename,1,1) FRO

Android-Animations介绍

一.Animations介绍 Animations是一个实现android UI界面动画效果的API,Animations提供了一系列的动画效果,可以进行旋转.缩放.淡入淡出等,这些效果可以应用在绝大多数的控件中. 二.Animations的分类 Animations从总体上可以分为两大类: 1.Tweened Animations:该类Animations提供了旋转.移动.伸展和淡出等效果.Alpha——淡入淡出,Scale——缩放效果,Rotate——旋转,Translate——移动效果.

android - Animation详解

Drawable 最强大的功能是:显示Animation.AndroidSDK介绍了2种Animation: Tween Animation(渐变动画):通过对场景里的对象不断做图像变换(平移.缩放.旋转)产生动画效果 Frame Animation(帧动画)   :顺序播放事先做好的图像,类似放电影 在使用Animation前,我们先学习如何定义Animation,这对我们使用Animation会有很大的帮助.Animation是以XML格式定义的,定义好的XML文件存放在res/anim中.

Android资源文件中各种XML的作用与解释

众所周知,XML是一种可扩展标记语言,它被用来传输和存储数据.在Android中也会随处可见XML文件,包括一个android项目不可缺少的AndroidManifest.xml清单文件,res资源文件目录下的anim/drawable/layout/menu/values中等,目录截图如下.其中清单文件中内容最多最复杂,完全可以在其他文章中再来讲解,所以本文主要讲解res目录下的XML的作用与内容. 一.anim目录 anim目录下的xml主要是用于android中的动画,包括Frame an

android 动画(转载)

转载地址:http://www.cnblogs.com/qiengo/archive/2012/05/03/2480386.html Android Animation Contents: Animations Tween Animations AnimationSet Interpolator Frame-By-Frame Animations LayoutAnimationsController AnimationListener  Animations 一.Animations介绍 Ani

安卓动画为了,写购物车动画,搜集的安卓动画的代码

 Animations 一.Animations介绍 Animations是一个实现android UI界面动画效果的API,Animations提供了一系列的动画效果,可以进行旋转.缩放.淡入淡出等,这些效果可以应用在绝大多数的控件中. 二.Animations的分类 Animations从总体上可以分为两大类: 1.Tweened Animations:该类Animations提供了旋转.移动.伸展和淡出等效果.Alpha--淡入淡出,Scale--缩放效果,Rotate--旋转,Trans