当前位置: 首页 > news >正文

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



版权声明: 原创作品,答应转载,转载时请务必以超链接形式标明文章 原始因由 、作者信息和本声明。不然将究查轨则责任。

转载于:https://www.cnblogs.com/zgqjymx/archive/2011/03/07/1976295.html

相关文章:

  • 使用SQL语句中between and查询数据出错
  • 网络编程[31]
  • 设置数据库兼容级别的两种方法
  • wordpress之模板汉化
  • 虚拟主机运行Asp.net MVC2程序体验(在不同版本的 IIS 上使用 ASP.NET MVC(转),付程序示例 )...
  • SQL Server 的最大容量规范
  • VC命名规范
  • 一步一步学习C#中的多线程 --- 1、初识线程(2)--给线程传递参数
  • PL/SQL是什么
  • DDL触发器学习整理
  • quote symbol expected
  • SQL语句新建用户、对用户授权、删除用户实例
  • android文件下载!download!
  • SQL Server 2008 表变量参数(表值参数)用法
  • Java类加载器加载类顺序
  • 230. Kth Smallest Element in a BST
  • ECMAScript入门(七)--Module语法
  • ES6之路之模块详解
  • node入门
  • PHP 程序员也能做的 Java 开发 30分钟使用 netty 轻松打造一个高性能 websocket 服务...
  • socket.io+express实现聊天室的思考(三)
  • spring + angular 实现导出excel
  • 从tcpdump抓包看TCP/IP协议
  • 官方解决所有 npm 全局安装权限问题
  • 警报:线上事故之CountDownLatch的威力
  • 每天一个设计模式之命令模式
  • 配置 PM2 实现代码自动发布
  • 使用parted解决大于2T的磁盘分区
  • 阿里云IoT边缘计算助力企业零改造实现远程运维 ...
  • ​​​​​​​sokit v1.3抓手机应用socket数据包: Socket是传输控制层协议,WebSocket是应用层协议。
  • !$boo在php中什么意思,php前戏
  • (M)unity2D敌人的创建、人物属性设置,遇敌掉血
  • (带教程)商业版SEO关键词按天计费系统:关键词排名优化、代理服务、手机自适应及搭建教程
  • (附源码)spring boot网络空间安全实验教学示范中心网站 毕业设计 111454
  • (学习日记)2024.02.29:UCOSIII第二节
  • (转) Android中ViewStub组件使用
  • (转)setTimeout 和 setInterval 的区别
  • *++p:p先自+,然后*p,最终为3 ++*p:先*p,即arr[0]=1,然后再++,最终为2 *p++:值为arr[0],即1,该语句执行完毕后,p指向arr[1]
  • .libPaths()设置包加载目录
  • .NET Core 成都线下面基会拉开序幕
  • .NET MAUI学习笔记——2.构建第一个程序_初级篇
  • .netcore如何运行环境安装到Linux服务器
  • .NET使用存储过程实现对数据库的增删改查
  • .net中的Queue和Stack
  • @NoArgsConstructor和@AllArgsConstructor,@Builder
  • [2023-年度总结]凡是过往,皆为序章
  • [BZOJ 1032][JSOI2007]祖码Zuma(区间Dp)
  • [docker] Docker的私有仓库部署——Harbor
  • [GDOUCTF 2023]<ez_ze> SSTI 过滤数字 大括号{等
  • [Hadoop in China 2011] Hadoop之上 中国移动“大云”系统解析
  • [hdu2196]Computer树的直径
  • [JavaWeb学习] idea新建web项目
  • [java基础揉碎]方法的重写/覆盖
  • [Linux]创建新用户并授予root权限
  • [macOS] Mojave10.14 夜神安卓模拟器启动问题