Oracle学习系列5
************************************************************************************

    ,掌握表的建立与删除
        了解Oracle中的主要数据类型

    ,约束的分类和使用
    ,表的关联:交,并,补
    ,掌握ROWNUM伪列的作用
    ,掌握序列的使用
    ,掌握视图的作用
    ,了解同义词,用户管理,权限分配与撤销,数据库的备份
------------------------------------------------------------------

创建和管理表(重点):

    常用的数据类型:

            number[int ,float], varchar ,date ,clob, blob,

    表的建立:

        create  table tab_name(

                col1    type   [defalut 默认值],
                col2    type   [default 默认值],
                ...
                coln    type    [default 默认值]

        )    ;

        create table  tab_name as (子查询)  ;//赋值表
        create table  tab_name =) ;//仅复制表结构

        ex:创建表person
            create table person(

                UID  varchar(),
                name  varchar(),
                age   number(),
                birthday  date,

                sex     varchar()  default '男'
                ) ;

            ex:向表中增加数据:
                insert into person(UID,name,age,birthday,sex)
                    values(,to_date('1994-04-09','yyyy-mm-dd'),'女');

            ex:表的删除:

                    drop table tab_name ;

                    eg:drop table person;

            ex:修改表结构:增加列,修改列

                    alter  table tab_name  add (col1 type default 默认值,
                                                col2 type default 默认值,
                                                ...
                                                coln type default 默认值

                            ) ;  //增加列

                   alter table person add (address  varchar()  default '暂无地址') ;

                   alter table tab_name  modify (col1 type default 默认值,
                                                col2 type default 默认值,
                                                ...
                                                coln type default 默认值

                            ) ;  //修改列

                    alter table person modify (name varchar2() default '无名氏');

                /**
                    若数据库中对应字段里有一个很长的数据,则无法将表长度缩小

                */

            ex:为表重命名

                    在oracle中提供了rename命令,对表进行重新命名。
                    rename  tab_name_old   to   tab_name_new ;

                    ex:
                        rename person to tperson ;

            ex:截断表

                若要清空一张表的数据,同时不需要回滚,可以立即释放资源就要使用
                    截断表的语法:
                        truncate  table tab_name ;

                        ex: truncate table tperson ;  //清空表数据
                            rollback ;     //使用rollback无效

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

思考题:
    现有一张国家表,里面有字段:中国,美国,巴西,荷兰,
    现要求通过查询实现对战功能:
            中国 ----> 美国
            中国 ----> 巴西
            中国 ----> 荷兰
            美国 ----> 中国
            美国 ----> 巴西
            美国 ----> 荷兰    

        问:此程序该如何实现?

            分析:使用笛卡尔积完成

                create table national(

                        name varchar()

                ) ;

                insert into national(name)
                    values('中国')    ;
                insert into national(name)
                    values('美国')    ;
                insert into national(name)
                    values('巴西')    ;
                insert into national(name)
                    values('荷兰')    ;

                select t1.name ,t2.name
                    from national t1, national t2
                        where t1.name <>t2.name ;        

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

约束(重点):

        分类:
            ,主键约束 -->是唯一的表示,本身不能为空,如身份证
            ,唯一约束 -->在一个表中只能建立一个主键约束,其他列不想出现重复值可使用唯一性约束
            ,非空约束 -->列的内容不能为空
            ,检查约束 -->检查一个列的内容是否合法
            ,外键约束 -->在两张表中进行的约束操作
---------------------------------------------------------------------------
    ,主键约束:

        create table person(

                UID  varchar()  primay key,     //主键约束
                name  varchar(),
                age   number(),
                birthday  date,
                sex     varchar()  default '男'

                ) ;
        /**
            create table person(

                UID      varchar(18)
                name       varchar(200),
                age      number(3),
                birthday  date,
                sex       varchar(2)  default '男',
                constraint person_uid_pk primary key(uid)  //指定uid主键约束名称

                ) ;

        */

---------------------------------------------------------------------------
,唯一约束 :unique

        表示一个字段中的内容是唯一的,其他列不允许重复

        create table person(

                UID      varchar()
                name       varchar()  unique  not null,  //非空约束,唯一约束
                age      number() not null,      //非空约束
                birthday  date,
                sex       varchar()  default '男',
                constraint person_uid_pk primary key(uid)  //指定uid主键约束名称

               <constraint person_name_uk unique(name)  >  //指定name唯一约束名称

                ) ;

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

,非空约束: not null

            表示一个字段的内容不允许为空,即插入数据时必须插入该字段的值

        create table person(

                UID      varchar()
                name       varchar()  not null,  //非空约束
                age      number() not null,      //非空约束
                birthday  date,
                sex       varchar()  default '男',
                constraint person_uid_pk primary key(uid)  //指定uid主键约束名称
                 <constraint person_name_nk not null(name)  >  //指定name非空约束名称

                ) ;

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

,检查约束                

            create table person(

                UID      varchar()
                name       varchar()  not null,  //非空约束
                age      number() not  and ),   //非空约束,检查约束
                birthday  date,
                sex       varchar()  default '男' check(sex in('男','女',‘中’)), //检查约束
                constraint person_uid_pk primary key(uid)  //指定uid主键约束名称

                 <constraint person_name_ck check(name)  >  //指定name检查约束名称

                 <constraint person_sex_ck check(sex)  >  //指定sex检查约束名称

                ) ;

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

,外键约束(foreign key):

        create table person(

                UID      varchar()
                name       varchar()  not null,  //非空约束
                age      number() not  and ),   //非空约束,检查约束
                birthday  date,
                sex       varchar()  default '男' check(sex in('男','女',‘中’)), //检查约束
                constraint person_uid_pk primary key(uid)  //指定uid主键约束名称

                 <constraint person_name_ck check(name)  >  //指定name检查约束名称

                 <constraint person_sex_ck check(sex)  >  //指定sex检查约束名称

        ) ;//创建person表

        create table book(

                    bid    number  primary key not null,
                    bname   varchar(),
                    bprice    number(,)
                    uid     varchar()

            constraint person_book_uid_fk  foreign key(uid)  references person(uid)  //外键约束

        );//创建book表

        /**
            1,在子表book中设置的外键在父表person中必须是主键
            2,删除时,先删除子表book,再删除父表person:
                    drop table book;
                    drop table person ;

        */

    ex:插入测试数据:

        insert into person(UID,name,age,birthday,sex)
                    values(,to_date('1994-04-09','yyyy-mm-dd'),'女');        

        insert into book (bid,bname,bprice)
            values(,');
    级联删除:

        create table book(

                    bid    number  primary key not null,
                    bname   varchar(),
                    bprice    number(,)
                    uid     varchar()

            constraint person_book_uid_fk  foreign key(uid)  references person(uid) on delete cascade  //外键约束,级联删除

        );//创建book表

        delete from person '; //删除一条记录,同时删除子表book中的记录
        


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

  1. Oracle学习系列1-7

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

  2. Oracle学习系列7

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

  3. Oracle学习系列6

    Oracle学习系列6 ************************************************************************************ 删除约 ...

  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. 《BI那点儿事》数据流转换——数据转换

    数据转换执行类似于T-SQL中的函数CONVERT或CAST的功能.数据转换的编辑界面如图,选择需要转换的列,在DataType下拉列表中选择需要的数据类型.Output Alias栏内设置输出时使用 ...

  2. Flex 文本控件实现自定义复制粘贴

    由于添加了自定义右键菜单,导致Textinput控件默认的右键复制粘贴功能被屏蔽了.最后通过JS脚本实现这个功能,参考代码如下 <?xml version="1.0" enc ...

  3. poj2280Amphiphilic Carbon Molecules(极角排序)

    链接 卡了几天的破题,对于hdu的那份数据,这就一神题.. 借助极角排序,枚举以每一个点进行极角排序,然后构造两条扫描线,一个上面一个下面,两条同时走,把上线和下线的点以及上线左边的点分别统计出来,如 ...

  4. RMAN的恢复篇

    Oracle 数据库的恢复实际上包含了两个概念:数据库修复(RESTORE)与数据库恢复(RECOVER): 数据库修复:是指利用备份的数据库文件来替换已经损坏的数据库文件或者将其恢复到一个新的位置. ...

  5. 【转】Hostapd工作流程分析

    [转]Hostapd工作流程分析 转自:http://blog.chinaunix.net/uid-30081165-id-5290531.html Hostapd是一个运行在用户态的守护进程,可以通 ...

  6. ORACLE分页查询SQL语法——最高效的分页

    --1:无ORDER BY排序的写法.(效率最高)--(经过测试,此方法成本最低,只嵌套一层,速度最快!即使查询的数据量再大,也几乎不受影响,速度依然!) SELECT * FROM (SELECT  ...

  7. react mixins编写

    var LogMixin = { componentWillMount: function () { console.log('Component will mount'); }, component ...

  8. C#日常总结1

    Rows:行的集合: Columns:列的集合: Gridview:用来显示数据的表格{ //设置 AutoGenerateColumns="false":表示不允许自动产生列,列 ...

  9. jsp项目与mysql链接

    因为毕设是地下车库管理系统,所以打算学习jsp进行开发~ 今天主要是[新建网站项目+mysql链接],在此篇之前所做的工作:tomcat服务器配置,mysql数据库的安装与启用(在之后的开发中可以使用 ...

  10. linux下多路复用模型之Select模型

    Linux关于并发网络分为Apache模型(Process per Connection (进程连接) ) 和TPC , 还有select模型,以及poll模型(一般是Epoll模型) Select模 ...