• Oracle基本知识


      起原:网海拾贝




    一个表空间只能属于一个数据库

    每个数据库起码有一个节制文件(首倡3个,分袂放在差异的磁盘上)

    每个数据库起码有一个表空间(SYSTEM表空间)

    设立建设SYSTEM表空间的目标是尽管将目标相反的表寄存在一起,以提高应用服从,只应寄存数据字典

    每个数据库起码有两个联机日记组,每组起码一个联机日记文件

    一个数据文件只能属于一个表空间

    一个数据文件一旦被参加到一个表空间中,就不克不及再从这个表空间中移走,也不克不及再参加到其他表空间中

    设立建设新的表空间需求设立建设新的数据文件

    数据文件被ORACLE花式化为ORACLE块,Oracle9i过去版本中,ORACLE块的巨细是在第一次设立建设数据库时设定的,而且当前不克不及改动,要想改动,只能重建数据库

    一个段segment只能属于一个表空间,但可以属于多个数据文件

    一个区extent只能属于一个数据文件,即区间(extent)不克不及凌驾数据文件

    PCTFREE和PCTUSED总和不克不及大于即是100

    零丁一个事件不克不及凌驾多个回滚段

    索引表不含ROWID值

    拥有差异巨细的回滚段没有任何益处

    COMMIT后,数据不消定赶忙写盘(数据文件)

    一个事件纵然不被提交,也会被写入到重做日记中。



    Oracle 8.0.4中,在初始安装时设立建设的缺省数据库,实例名为ORCL

    一个块的最大长度为16KB(有2K、4K、8K、16K)

    每个数据库最大文件数(按块巨细)

    2K块20000个文件

    4K块40000个文件

    8K块或以上 65536个文件

    oracle server可以同时启动多个数据库

    一套操纵琐屑上可以安装多个版本的ORACLE数据库琐屑(UNIX可以,NT不可以)

    一套ORACLE数据库琐屑中可以有多个ORACLE数据库及其绝对应的实例

    每个ORACLE数据库拥有一个数据库实例(INSTANCE)(OPS除外)以是,一套操纵琐屑上同时可以有多个oracle数据库实例启动 

    //Oracle8 数据规范

    char(n) n=1 to 2000字节 定长字符串,n字节长,若是不指定长度,缺省为1个字节长(一个汉字为2字节)

    varchar2(n) n=1 to 4000字节 可变长的字符串,详细定义时指明最大长度n,

    这种数据规范可以放数字、字母以及ASCII码字符集(也许EBCDIC等数据库琐屑经受的字符集尺度)中的统统标记。

    若是数据长度没有抵达最大值n,Oracle 8i会依据数据巨细主动调理字段长度,

    若是你的数据前后有空格,Oracle 8i会主动将其删去。VARCHAR2是最常用的数据规范。

    可做索引的最大长度3209。

    number(m,n) m=1 to 38

    n=-84 to 127 可变长的数值列,允许0、正值及负值,m是统统无效数字的位数,n是小数点当前的位数。

    如:number(5,2),则这个字段的最大值是99,999,若是数值凌驾了位数限定就会被截取多余的位数。

    如:number(5,2),但在一行数据中的这个字段输出575.316,则真正保留到字段中的数值是575.32。

    如:number(3,0),输出575.316,真正保留的数据是575。  

    date 无 从公元前4712年1月1日到公元4712年12月31日的一吻公道日期,

    Oracle 8i真实在外部是按7个字节来保留日期数据,在定义中还网罗小时、分、秒。

    缺省花式为DD-MON-YY,如07-11月-00 暗示2000年11月7日。  

    long 无 可变长字符列,最大长度限定是2GB,用于不需求作字符串搜索的长串数据,若是要停止字符搜索就要用varchar2规范。

    long是一种较老的数据规范,将来会逐步被BLOB、CLOB、NCLOB等大的对象数据规范所交换。  

    raw(n) n=1 to 2000 可变长二进制数据,在详细定义字段的时辰必需指明最大长度n,Oracle 8i用这种花式来保留较小的图形文件或带花式的文本文件,如Miceosoft Word文档。

    raw是一种较老的数据规范,将来会逐步被BLOB、CLOB、NCLOB等大的对象数据规范所交换。  

    long raw 无 可变长二进制数据,最大长度是2GB。Oracle 8i用这种花式来保留较大的图形文件或带花式的文本文件,如Miceosoft Word文档,以及音频、视频等非文本文件。

    在统一张表中不克不及同时有long规范和long raw规范,long raw也是一种较老的数据规范,将来会逐步被BLOB、CLOB、NCLOB等大的对象数据规范所交换。  

    blob

    clob

    nclob 无 三种大型对象(LOB),用来保留较大的图形文件或带花式的文本文件,如Miceosoft Word文档,以及音频、视频等非文本文件,最大长度是4GB。

    LOB有几品种型,取决于你应用的字节的规范,Oracle 8i实真实在地将这些数据存储在数据库外部保留。

    可以实验读取、存储、写入等出格操纵。  

    bfile 无 在数据库外部保留的大型二进制对象文件,最大长度是4GB。

    这种外部的LOB规范,经由数据库纪录变革情况,然则数据的详细保留是在数据库外部停止的。

    Oracle 8i可以读取、究诘BFILE,然则不克不及写入。

    巨细由操纵琐屑选择。  



    SQL(Structured Query Language)语句分类

    DDL、数据定义言语:create、alter、drop、truncate(设立建设、批改结构、删除、截断)(其他:rename)

    DML、数据操纵言语:insert、delete、select、update(增、删、查、改)

    DCL、数据节制言语:grant、revoke(受权、给与)、set role

    事件节制:commit、rollback、savepoint(其他:lock table、set constraint(s)、set transaction)

    审计节制:audit、noaudit

    琐屑节制:alter system

    会话节制:alter session

    其他语句:comment(添加注释)、explain plan、analyze(网络统计)、validate、call



    //SQL*Plus中运转的几种号令

    1. SQL*Plus号令          普通用来花式化究诘输出、设置情况、编辑存储SQL号令和PL/SQL块

      SQL> show user

      SQL> select user from dual;

    2. SQL号令

      SQL> select * from tab;

    3. PL/SQL块

      SQL> BEGIN

      DBMS_OUTPUT.PUT_LINE('Hello World!');

      END;



    //Oracle中完成某一字段主动增进1

    create sequence 序列名

    increment by 1

    start with 1

    maxvalue 999999999

    cycle;

    当向表中拔出数据时,SQL语句写法如下:

    SQL> insert into 表名 values(序列名.nextval,列1值,列2值);


    //怎样用SQL生成SQL批处置文件?

    软件情况:

    1、Windows NT4.0 ORACLE 8.0.4

    2、ORACLE安装途径为:C:ORANT

    标题问题提出:

    1、用户需求对数据库用户下的每一张表都实验一个相反的SQL操纵,这时,一遍、一遍的键入SQL语句是很费事的

    完成方法:

    SQL> set heading off --克制输出列标题问题

    SQL> set feedback off --克制显现最月朔行的计数反应信息

    列出当前用户下统统同义词的定义,可用来测试同义词的真实存在性

    select 'desc '||tname from tab where tabtype='SYNONYM';

    究诘当前用户下统统表的纪录数

    select 'select '''||tname||''',count(*) from '||tname||';' from tab where tabtype='TABLE';

    把统统相宜前提的表的select权限赋予为public

    select 'grant select on '||table_name||' to public;' from user_tables where 《前提》;

    删除用户下各类对象

    select 'drop '||tabtype||' '||tname from tab;

    删除相宜前提用户

    select 'drop user '||username||' cascade;' from all_users where user_id>25;

    疾速编译统统视图

    ----当在把数据库倒入到新的服务器上后(数据库重建),需求将视图重新编译一遍,

    ----由于该表空间视图到另外表空间的表的衔接会出现标题问题,可以利用PL/SQL的言语特性,疾速编译。

    SQL> SPOOL ON.SQL

    SQL> SELECT'ALTER VIEW '||TNAME||' COMPILE;' FROM TAB;

    SQL> SPOOL OFF

    然后实验ON.SQL即可。

    SQL> @ON.SQL

    固然,受权和设立建设同义词也可以疾速停止,如:

    SQL> SELECT 'GRANT SELECT ON '||TNAME||' TO 用户名;' FROM TAB;

    SQL> SELECT 'CREATE SYNONYM '||TNAME||' FOR 用户名.'||TNAME||';' FROM TAB



    版权声明: 原创作品,允许转载,转载时请务必以超链接方法标明文章 原始情由 、作者信息和本声明。否则将追查功令责任。

  • 相关阅读:
    双元素非递增(容斥)--Number Of Permutations Educational Codeforces Round 71 (Rated for Div. 2)
    两两内积为0(牛客多校第七场)-- CDMA
    十进制快速幂(牛客多校第五场)-- generator 1
    分层最短路(牛客第四场)-- free
    %300为0的个数(牛客第四场)-- number
    3的倍数 或运算构造x(牛客第四场)-- triples I
    笛卡尔树--牛客第四场(sequence)
    线性基求交(线段树)--牛客第四场(xor)
    最短meeting路线(树的直径)--牛客第四场(meeting)
    最长相同01数的子串(map搞搞)--牛客第三场 -- Crazy Binary String
  • 原文地址:https://www.cnblogs.com/zgqjymx/p/1976337.html
Copyright © 2020-2023  润新知