Oracle学习系列6
************************************************************************************

删除约束(重点):

        格式:

            alter table person drop constraint constraint_name ;

        创建person表:

            create table person(

                UID      varchar()
                name       varchar()  not null,  //非空约束
                age      number() not null,      //非空约束
                birthday  date,
                sex       varchar()  default '男',

                ) ;

            /**
                主键约束:主键字段_PK
                唯一约束:字段_UK
                检查约束:字段_CK
                外键约束:父字段_子字段_FK
            */

            ex:为表添加若干个约束,

            格式:

                alter table tab_name add constraint constraint_name   constraint_type(constrain_colx)  ;

            ex:添加约束

            alter table person add constraint person_uid_PK primary key(uid);//增加主键约束
            alter talbe person add constraint person_name_UK unique(uid); //增加唯一约束
            alter table person add constraint person_age_CK checke(age between  and ) ;
            alter table person add constraint person_sex_CK check(sex in ('男','女','中')) ;

            ex:删除约束

            alter table person drop constraint person_uid_PK ;//删除主键约束
            alter talbe person drop constraint person_name_UK ; //删除唯一约束
            alter table person drop constraint person_age_CK  ; //删除检查约束
            alter table person drop constraint person_sex_CK  ; //删除检查约束

************************************************************************************

rownum(重点):
            rownum:    表示行号,实际上是一个伪列,可在每张表中出现

            select rownum, empno, ename ,job,sal,hiredate
                from emp ;  //  ROWNUM 采用自动编号的方式呈现    

            ex:
                select rownum, empno, ename, job, sal hiredate
                    from emp
                         ;
************************************************************************************

建表、约束、查询综合练习:

        题目背景:

            有某个学生运动会比赛信息的数据库,保存了如下的表:
                运动员sporter(运动员编号sporterid, 运动员姓名name, 运动员性别sex, 所属系好department)
                项目item (项目编号itemid, 项目名称itemname, 项目比赛地点location)
                成绩grade(运动员编号sportid,项目编号itemid, 积分mark)

        1建表要求:    

            a,定义各个表的主键外码约束
            b,运动员的姓名和所属系别不能为空值
            c,积分要么为null,要么为6,,,,分别代表第一二三和其他名词的积分

        create table sporter(

                sporterid       nummber()  primary key  not null,
                name            varchar2()  not null,
                sex                varchar2()  not null,
                department        varchar2()  not null,

                constraint sporter_sex_CK  check(sex in('男','女'))

        );                                        

        create table item(

            itemid        varchar2()  primary key not null,
            itemname    varchar2()  not null,
            location    varchar2()  not null        

        );

        create table grade(

                sporterid        number(),
                itemid            varchar2(),
                mark            number(),

                constraint sporter_grade_sporterid_FK  foreign key(sporterid)
                        references sporter(sporterid)  on delete cascade
                constraint item_grade_itemid_FK  foreign key(itemid)
                        references item(itemid)  on delete cascade
                constraint grade_mark_CK check(mark ,,,))

        );        

        测试数据:

            insert into  sporter(sportid, name, sex, department )
                values(,'黎明','男','计算机系');

            insert into  sporter(sportid, name, sex, department )
                values(,'张三','男','数学系系');

            insert into  sporter(sportid, name, sex, department )
                values(,'李四','男','计算机系');

            insert into  sporter(sportid, name, sex, department )
                values(,'王五','男','物理系');

            insert into  sporter(sportid, name, sex, department )
                values(,'李楠','女','心理系');

            insert into  sporter(sportid, name, sex, department )
                values(,'孙俪','女','艺术系');

            ---------------------------------------------------------
            insert into item(itemid ,itemname, location)
                    values('x001','男子五千米','一操场') ;

            insert into item(itemid ,itemname, location)
                    values('x002','男子标枪','一操场') ;

            insert into item(itemid ,itemname, location)
                    values('x003','男子跳远','二操场') ;

            insert into item(itemid ,itemname, location)
                    values('x004','女子跳高','二操场') ;

            insert into item(itemid ,itemname, location)
                    values('x005','女子三千米','三操场') ;
            ---------------------------------------------------------

            insert into grade(sporterid, itemid,mark)
                    values(,);

            insert into grade(sporterid, itemid,mark)
                    values(,);

            insert into grade(sporterid, itemid,mark)
                    values(,);

            insert into grade(sporterid, itemid,mark)
                    values(,);

            insert into grade(sporterid, itemid,mark)
                    values(,);

            insert into grade(sporterid, itemid,mark)
                    values(,);

            insert into grade(sporterid, itemid,mark)
                    values(,);

            insert into grade(sporterid, itemid,mark)
                    values(,);
            insert into grade(sporterid, itemid,mark)
                    values(,);

        要求:
            求出目前总积分最高的系名,及其积分:
                select * from (

                           select s.department , sum(g.mark) sum
                            from  sporter s, grade g
                                where s.sporterid=g.sporterid
                                    group by s.department
                                        order by sum desc
                            )

            找出在一操场进行比赛的各项目名称及其冠军的姓名:
                select i.itemname, s.name, g.mark
                    from item i, grade g,sporter s
                        where i.location='一操场'
                            and i.itemid=g.itemid
                            and s.sporterid=g.sporterid
                            and g.mark= ;        

            找出参加了张三所参加过的项目的其他同学的姓名:
                select distinct s.name
                    from sporter s, grade g
                        where s.sporterid=g.sporterid and s.name <>'张三'
                            and g.itemid IN (

                                select g.itemid from sporter s ,grade g
                                    where s.sporterid=g.sporterid
                                        and s.name='张三'

                                ) ;

            经查张三使用了违禁药品,其成绩都记0分,请在数据库中做出相依修改:
                update grade 

                        where sporterid =(

                                select sportid from sporter where name ='张三'
                            ) ;

            经组委会协商,需要删除女子跳高比赛项目:
                delete from item
                    where itemname='女子跳高' ;

------------------------------------------------------------
    删除顺序:    //先删子表,再删主表
        drop table grade;
        drop table sporter;
        drop table item ;

************************************************************************************
集合操作:

        分类:
                并(UNION) :将多个查询的结果组合到一个查询结果中,无重复值 //UNIONALL:包含重复值
                 交(INTERSECT):返回多个查询结果相同的部分
                 差(MINUS) :返回两个结果的差集

        复制emp表,将部门20的雇员信息取出来:
            create table emp20
                as select * from emp
                         ;

        验证UNION:
            select * from emp
            union
            select * from emp20 ;

        验证UNIONALL:
            select * from emp
            unionall
            select * from emp20 ;

        验证INTERSECT:
            select * from emp
            INTERSECT
            select * from emp20 ;

        验证MINUS:
            select * from emp
            minus
            select * from emp20 ;

----------------------------------------------------------------------------------

SQL查询最终格式:

////////////////////////////////////////////////////////////////////////////////////////////
            select { distinct } * | col1 别名1   col2 别名2 ...
                from  tab1 别名1 , tab2 别名2 ,
                    (
                        select { distinct } * | col1 别名1   col2 别名2 ...
                            from  tab1 别名1 , tab2 别名2 , tab3 别名3 ,...
                                {where 条件s }
                                    {group by 分组条件   { having  分组条件 }  }
                                        { order by col1 ASC | DESC , col2  ASC | DESC, ...} ;

                     )别名x     tab3 别名3 ,...
                    {where 条件s
                        (
                        select { distinct } * | col1 别名1   col2 别名2 ...
                            from  tab1 别名1 , tab2 别名2 , tab3 别名3 ,...
                                {where 条件s }
                                    {group by 分组条件   { having  分组条件 }  }
                                        { order by col1 ASC | DESC , col2  ASC | DESC, ...} ;

                     )

                    }
                        {group by 分组条件   { having  分组条件 }  }
                            { order by col1 ASC | DESC , col2  ASC | DESC, ...} ;

            {UNION | INTERSECT |MINUS}

                select { distinct } * | col1 别名1   col2 别名2 ...
                    from  tab1 别名1 , tab2 别名2 ,
                        (
                        select { distinct } * | col1 别名1   col2 别名2 ...
                            from  tab1 别名1 , tab2 别名2 , tab3 别名3 ,...
                                {where 条件s }
                                    {group by 分组条件   { having  分组条件 }  }
                                        { order by col1 ASC | DESC , col2  ASC | DESC, ...} ;

                             )别名x     tab3 别名3 ,...
                        {where 条件s
                            (
                            select { distinct } * | col1 别名1   col2 别名2 ...
                                from  tab1 别名1 , tab2 别名2 , tab3 别名3 ,...
                                    {where 条件s }
                                        {group by 分组条件   { having  分组条件 }  }
                                        { order by col1 ASC | DESC , col2  ASC | DESC, ...} ;

                                 )

                        }
                            {group by 分组条件   { having  分组条件 }  }
                                { order by col1 ASC | DESC , col2  ASC | DESC, ...} ;

////////////////////////////////////////////////////////////////////////////////////////////        

Oracle学习系列6的更多相关文章

  1. Oracle学习系列1-7

    Oracle学习系列1 两个服务必须启动: OracleOraDb10g*TNListener 和 OracleService*** 使用sqlplusw先进行环境的设置 set linesize 3 ...

  2. Oracle学习系列7

    Oracle学习系列7 ************************************************************************************ 关联表 ...

  3. Oracle学习系列5

    Oracle学习系列5 ************************************************************************************ ,掌握 ...

  4. Oracle学习系列4

    Oracle学习系列4 ************************************************************************************ 数据库 ...

  5. Oracle学习系列3

    Oracle学习系列3 ************************************************************************************ 多表查 ...

  6. Oracle学习系列1

    两个服务必须启动: OracleOraDb10g*TNListener 和 OracleService*** 使用sqlplusw先进行环境的设置 set linesize 300 ; set pag ...

  7. oracle学习系列之四 (视图)

    视图视图是数据库中特有的对象.视图用于存储查询,但不会存储数据(物化视图除外).这是视图和数据表的重要区别.可以利用视图进行查询,插入,更新和删除数据.Oracle有如下四种视图(关系视图,内嵌视图, ...

  8. oracle学习系列之三 (约束)

    主键约束:外键约束:唯一性约束:检查约束:默认值约束 -——————五大约束 一. 主键约束: --创建表的主键约束  create table student (student_id number ...

  9. Oracle 学习系列之二(会话与事务级临时表和dual表 )

    一. 会话临时表 --创建会话临时表create global temporary table tmp_user_session(user_id int, user_name varchar2(20) ...

随机推荐

  1. [hdu1394]Minimum Inversion Number(树状数组)

    Minimum Inversion Number Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java ...

  2. Point ZM 转换为Point 类型

    打开ArcToolbox,使用ConvertionTools-> To Shapefile->FeatureClass to Shapefile 工具,注意在环境设置里,里将output ...

  3. Deep Learning 17:DBN的学习_读论文“A fast learning algorithm for deep belief nets”的总结

    1.论文“A fast learning algorithm for deep belief nets”的“explaining away”现象的解释: 见:Explaining Away的简单理解 ...

  4. HTML5 十大新特性(一)——语义标签

    说语义标签前先来理解下什么叫语义化,当下html是靠div+css来铸造页面的整体框架和结构的,通篇大量的div可读性极低,因此诞生了这些特殊的标签,简单地说就是见名知义,使页面更清晰,方便维护和开发 ...

  5. Linux系统下Apache2.4.17的安装过程

    Linux系统下安装Apache Server2.4.17.还是先声明一下,Linux命令我不进行讲解,因为我不是讲Linux命令的.有需要注意的地方,我会上图,没什么值得的注意的地方,我就不上图了. ...

  6. PDF 补丁丁 0.4.2.1023 测试版发布:新增旋转页面功能

    新的测试版发布啦.此版本增加了旋转页面的功能. 在“PDF文档选项”对话框的“页面设置”选项卡中,可设置需要旋转的页面(输入页码范围),以及旋转角度. 此外,还修复了统一页面尺寸功能的小问题.

  7. Java:Collection List Set

    Java:集合 常见集合:List Set List 特点:元素是有序的,而且元素可以重复,因为该集合体系有索引. 常见的三个子类:ArrayList.LinkedList.Verctor List集 ...

  8. 源代码tfs to git

    TFSàgit可以保留完整历史记录,方法: https://github.com/git-tfs/git-tfs 系统变量的path里加上: ;C:\Program Files (x86)\Git\b ...

  9. iOS开发UI篇—ios应用数据存储方式(偏好设置)

    iOS开发UI篇—ios应用数据存储方式(偏好设置) 一.简单介绍 很多iOS应用都支持偏好设置,比如保存用户名.密码.字体大小等设置,iOS提供了一套标准的解决方案来为应用加入偏好设置功能 每个应用 ...

  10. windows下安装mysql解压版

    1.解压压缩版的MySQL 其中: bin目录        -    主要存放MySQL的各种可执行程序 data目录      -   存放数据库的数据文件和索引文件等 MySQL-test -  ...