zoukankan      html  css  js  c++  java
  • Oracle 数据类型

    Oracle 数据类型

    创建表时,必须为各个列指定数据类型

    以下是 Oracle 数据类型的类别:


     

     

    Oracle主要数据类型

    Character 数据类型

    Char:固定长度字母数字值,可1-2000个字节

    Varchar2:可变长度,1-4000个字节

    Long:可变长度,最多2G

    Number 数据类型

    可以存储整数、浮点数和实数

    最高精度为 38 位

    格式: NUMBER [( p[, s])]

    Date 数据类型

    存储日期和时间值

    Date:存储日期和时间部分,精确到整个的秒

    Timestamp:存储日期、时间和时区信息,秒值精确到小数点后6位

    RAW/LONG RAW数据类型

    RAW:存储二进制数据,最多2000字节

    LONG RAW:用于存储可变长度的二进制数据,最多2GB

    LOB数据类型

    称为“大对象”数据类型,可以存储多达 4GB 的非结构化信息,例如声音剪辑和视频文件等,允许对数据进行高效、随机、分段的访问

    CLOB:字符数据;BLOB:二进制对象,如图形、视频、音频等;BFILE :即 Binary File(二进制文件),它用于将二进制数据存储在数据库外部的操作系统文件中

     

    SQL 语句复习

    SQL 支持下列类别的命令:

    数据定义语言(DDL):用于改变数据库结构

    CREATE  ALTER  DROP

    数据操纵语言(DML):用于检索修改和插入数据

    INSERT  SELECT  DELETE UPDATE

    事务控制语言(TCL):保证事务的执行

    COMMIT  ROLLBACK  SAVEPOINT

    数据控制语言(DCL):提供权限控制命令

    GRANT  REVOKE

     

    表管理--创建表

    利用现有的表创建表

    语法:

    CREATE TABLE <new_table_name> AS SELECT column_names FROM <old_table_name>;

    示例:

    SQL> CREATE TABLE newemp

               AS SELECT * FROM emp[WHERE 1 = 2;];

    SQL> CREATE TABLE newemp

               AS SELECT empno, salary

               FROM emp;

     

    表管理--约束

    五大约束

    1、非空约束:NOT NULL

    2、主键约束:PRIMARY KEY,唯一、且非空

    3、外键约束:FOREIGN KEY ... REFERENCES

    4、唯一约束:UNIQUE,唯一,允许为空

    5、条件约束:CHECK

    列级约束

    约束作为列定义的一部分,允许定义全部的五类约束

    SQL> CREATE TABLE clazz_table (

              cid NUMBER(10)PRIMARY KEY,

              cname VARCHAR2(30) NOT NULL,

              cdate DATE);

    SQL> CREATE TABLE student_table(

              sid NUMBER(10) primary key ,

              clazzid NUMBER(10)REFERENCES clazz_table(cid),

              sno VARCHAR2(30)UNIQUE,

              sname VARCHAR(30) NOT NULL,

              sage NUMBER(3) CHECK(sage>0 AND sage<120));

    注意:

    列名、数据类型、缺省值的次序不能乱;

    在列定义的最后,指定列类型的约束;

    主键约束的列可以不指定非空约束(NOT NULL)。

    表级约束

    约束作为表定义的一部分,除非空约束外,允许定义其他四类约束

    唯一约束

    CONSTRAINT nameUNIQUE(column[,column...])‏

    主键约束

    CONSTRAINT name PRIMARY KEY(column[,column...])‏

    外键约束

    CONSTRAINT name FOREIGN KEY (column[,column...]) REFERENCES table(column[,column...])

    条件约束

    CONSTRAINT name CHECK(condition)‏

    定义表级约束

    SQL>create table account(

    name VARCHER2(32) ,

    acc_type NUMBER(1) NOT NULL,

    acc_code VARCHAR2(32),

    ba NUMBER(5,2) DEFAULT 100,

    CONSTRAINT pk_qrsx_account PRIMARY KEY (name),

    CONSTRAINT uk_qrsx_account UNIQUE(acc_code),

    CONSTRAINT ck_qrsx_account CHECK(ba>=100 AND ba<=1000));

     

    表管理--修改表

    ALTER TABLE :修改表

    列的添加、修改

    给表添加/删除约束

    语法:

    ALTER TABLE[add][modify][drop column]

    示例:

    alter table users add(pubdate date);

    alter table users add(age number)

    alter table users modify(userName varchar2(20));

    alter table users drop(password);

    alter table users add primary key(userId);

     

    表管理--其它

    RENAME table_name TO new_name :重命名

    TRUNCATE TABLE:删除表 ,记录不可恢复

    DROP TABLE:删除表

    COMMENT ON:为表添加注释

    示例:

    RENAME users to test

    DROP TABLE users;--删除表结构

    TRUNCATE TABLE users --删除记录,释放空间

    DELETE FROM emp --删除记录,但可以恢复

    COMMENT ON TABLE emp IS 'Employee Information';

     

    Oracle数据库中的表

    用户表

    用户创建和维护的一系列表的集合包含用户的信息

    数据字典

    Oracle 服务器创建和维护的一系列表和视图的集合,包含数据库的信息

    user_xxx用户拥有的

    all_xx 用户有权查看

    dba_xxx(sys)  所有的信息

     

    数据控制语言DCL

    数据控制语言为用户提供权限控制命令

    用于权限控制的命令有:

    GRANT 授予权限

    REVOKE 撤销已授予的权限

    示例:

    SQL> GRANT ALL ON EMP TO TEA;

    SQL> REVOKE SELECT, UPDATE ON EMP FROM TEA;

  • 相关阅读:
    WCF message logging and tracing
    How to create a custom composite activity
    两个Datatable合并
    JS生成柱形图表
    InstallShiled12激活过程
    InstallShield Premier版本和Professional版本的功能差异
    InstallShield12注册过程
    Oracle回收站使用
    SQLite数据库管理的相关命令
    Installshield 2010 预安装组件或软件
  • 原文地址:https://www.cnblogs.com/Im-Victor/p/7581693.html
Copyright © 2011-2022 走看看