Oracle数据库常用技术

一、视图(重点)

什么是视图?

·视图由一个或多个表(或视图)中提取数据而成

·视图是一种虚拟表

·视图一经创建,可以当作表来使用。

使用视图的好处?

· 简化复杂数据查询

· 提高运行效率

· 屏蔽数据库表结构,实现数据逻辑独立性

· 限制数据库访问

· 在相同数据上提供不同的视图,便于数据共享

命名规范:

·以V开头,后加视图名 :VEMP10

·以系统名v_+模块名作为前缀 ,例:V_SECTION

·VIEW_VDU_ADMINISTRATORS

·视图名_VU: user view

创建视图:

创建视图的语法:

CREATE VIEW 视图名称 AS 子查询 ;

创建视图的步骤:

1:先把查询语句写正确

2:  然后在添加视图语句

注意:在写子查询时不能使用  SELECT *

程序员手则:严禁使用 SELECT * FROM 表名

删除视图

替换视图:

CREATE OR REPLACE 视图名称 AS 子查询 ;

创建不可更新视图:

· WITH CHECK OPTION:不能更新视图的创建条件

例:在视图创建中使用此参数

1 CREATE OR REPLACE VIEW empv202 AS3       SELECT * FROM emp WHERE deptno=204 WITH CHECK OPTION ;

UPDATE empv20 SET deptno=30 WHERE empno=7369 ;

更新语句不起作用

创建视图:

· WITH READ ONLY:创建的视图只读

例:创建只读视图

1 CREATE OR REPLACE VIEW empv202 AS3 SELECT * FROM emp WHERE deptno=204 WITH  READ  ONLY ;

二、存储进程Procedure

三、段user_segments和区user_extents

空间以段(segment)为单位分配给对象(如表、群集和索引),它们在物理上对应于在数据库中创建的逻辑对象

Oracle中的段(segment)是占用磁盘空间的一个对象,

常见段的类型有:

聚簇cluster

表table

表分区tablepartition

索引index

索引分区

Lob分区、Lob子分区、Lob索引、Lob段

嵌套表nestedtable

回滚段rollback。

select * from user_segments;

在11gR2中,一张表只有插入数据后才会分配段空间

一个段中可能有多种不同的表,段包含区,区包含块。同时表也包含区和块。

段由称为区(extent)的连续区域组成

四、SQLLoader

五、字符集

博客:http://blog.itpub.net/118838/viewspace-730214/

查看数据库字符集

数据库服务器字符集select * from nls_database_parameters,其来源于props$,是表示数据库的字符集。

客户端字符集环境select * from nls_instance_parameters,其来源于v$parameter,

客户端的字符集要求与服务器一致,才能正确显示数据库的非Ascii字符。

修改数据库UTF-8编码

例如把字符集GB2312修改为UTF-8步骤:

 1.在SQL*PLUS 中,以DBA登录conn 用户名 as sysdba
2.执行转换语句:
SHUTDOWN IMMEDIATE;
STARTUP MOUNT EXCLUSIVE;
ALTER SYSTEM ENABLE RESTRICTED SESSION;
ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0;
ALTER SYSTEM SET AQ_TM_PROCESSES=0;
ALTER DATABASE OPEN;
ALTER DATABASE NATIONAL CHARACTER SET UTF8;
SHUTDOWN immediate;
startup;

可能报错:‘ORA-12717: Cannot ALTER DATABASE NATIONAL CHARACTER SET whenNCLOB data exists’

解决方法:

一、使用INTERNAL_USE 关键字修改区域设置

 SHUTDOWN IMMEDIATE;
STARTUP MOUNT EXCLUSIVE;
ALTER SYSTEM ENABLE RESTRICTED SESSION;
ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0;
ALTER SYSTEM SET AQ_TM_PROCESSES=0;
ALTER DATABASE OPEN;
ALTER DATABASE NATIONAL CHARACTER SET INTERNAL_USE UTF8;
SHUTDOWN immediate;
startup;

行式数据库

列式数据库

上一篇:2. Python的划分


下一篇:AI零基础入门之人工智能开启新时代—上篇