Oracle面试题

1、关系数据库系统与文件数据库系统的区别在那里?关系数据库系统一般适用那些方面?

关系数据库系统文件系统的区别在于:

关系性数据库的整体数据是结构化的,采用关系数据模型来描述,这是它与文件系统的根本区别。(数据模型包括:数据结构,数据操作以及完整性约束条件)

关系数据库系统的共享性高,冗余低可以面向整个系统,而文件系统则具有应用范围的局限性,不易扩展。

关系数据库系统采用两级映射机制保证了数据的高独立性,从而使得程序的编写和数据都存在很高的独立性。这方面是文件系统无法达到的,它只能针对于某一个具体的应用。(两级映射:保证逻辑独立性的外模式/模式映射和保证物理独立性的内模式/模式映射。外模式:用户模式,是数据库用户的局部数据的逻辑结构特征的描述。模式:数据库全体数据的逻辑结构特征的描述。内模式:也就是数据最终的物理存储结构的描述。)

关系性数据库系统由统一的DBMS进行管理,从而为数据提供了如安全性保护,并发控制,完整性检查和数据库恢复服务。

 

2、sql语句例外(异常)处理?举例说明?

当sql 语句在执行过程中出现意外时,如查询时,未查询到结果;更改时无记录等情况的应采取的措施.

以oracle为例:测试其对exception的理解.如

select 字段 into 变量 from table ;

若查询出多条记录,应增加exception 例外处理.

Oracle处理异常有三种:

1.预定义的例外处理,EXCEPTION WHEN exception_name THEN

2.EXCEPTION_INIT产生例外

首先要declare 声明一个例外名;然后将例外名和错误代码绑定pragma exception_init(错误名,错误代码);最后在EXCEPTION 处when 错误名then

3.用户自定义例外,不用EXCEPTION,当判断条件成熟时用raise_application_error(-20000~~~-20999,提示信息)。

 

3、对于精通的数据库系统描述其体系结构,主要包括存储机制、回滚机制、运行机制等.

对oracle 系统而言,描述sga的结构; 后台pmon,ckpt、lgwr,smon等进程的功能;表空间的分配策略; 回滚段的结构

oracle的sga(系统全局区)包括的主要区有:数据库缓存区,重做日志缓存区,共享池(数据字典缓存和库缓存),大池等。数据库缓存区用来存放最近使用过的数据块主要和后台进程中的数据库写进程(DBWR)以及数据文件发生关系;重做日志缓存区用于存放操作数据库数据所产生的重做日志信息,与之合作的有重做日志写进程(LGWR)和重做日志文件;共享池主要缓存SQL/PLSQL,资源锁,控制信息等,其中的库缓存主要缓存被解析执行过的SQL/PLSQL库缓存可分为共享SQL和私有SQL两个区,共享SQL用于存放SQL语句的语法分析结果和执行计划,私有SQL则用来存放与具体SQL语句执行有关的绑定变量,会话参数等。

ORACLE实例的另外一个重要部分就是其后台进程,主要的后台进程有:数据库写进程(DBWR),重做日志写进程(LGWR),系统监视器(SMON),进程监视器(PMON),检查点进程(CKPT)。DBWR主要是对数据库缓存区中的脏冷数据进行写入数据文件操作;LGWR主要是将对数据库数据操作所产生的重做日志信息写入到重做日志文件中;SMON完成由于非正常关闭数据库的情况下重起数据库时对数据库的恢复;PMON用来恢复失败的用户进程和服务进程,并释放其所占的系统资源;CKPT可以表示数据库在此出处于完整状态。

逻辑存储结构:数据块BLOCK,区EXTENT,段SEGMENT,表空间TABLESPACE

物理存储空间:表空间,数据文件,控制文件,日志文件,数据字典

软件体系结构就是上边对SGA和后台进程的描述。

 

4、在创建表的时候会设置

pctfree 10

pctused 40

而创建表的索引的时候却没有

pctused 40

这是为什么?

(这道题的主要思想是索引不能在pctused 40上得到什么好处)

 

5、使用过的最大的表有多少行纪录?

(这道题不是看应试者的技术过不过关,而是考察应试者是否有大型数据库的管理操作经验)

不要对表的索引列进行函数操作,因为这样系统就不能使用索引,使查询变得很慢,但是在ora8i以后就已经开始支持函数的索引,弥补了这个不足。

 

6、Oracle使用什么语句给用户分配权限?

GRANT TO 语句

 

7、一张表有10万条记录,如何删除其中的任意20条记录?请用SQL语句进行操作

delete from table order by random() limit 20

order by random() ,相当于不是根据某个字段来排序,而是乱序。这个方法可以帮助制造混乱分布的测试数据。

 

8、oracle中执行语句错误时去哪里查找错误信息?

Select * from USER_ERRORS

 

9、oracle中有哪些类型的文件?

数据文件,控制文件,日志文件和数据字典

 

10、介绍一下oracle的体系结构?

逻辑体系结构:块,区,段,表空间

物理体系结构:表空间,三大文件

软件体系结构:SGA,后台进程

 

11、谈谈对oracle的row_ id是否理解?

ORACLE的row_id是一个伪列,其个是为18个字节可将这18个字节用6363来划分,分别表示段编号,数据文件编号,数据块编号和记录编号。

Row_id表示的是一个记录的物理存储地址。

 

12、oracle中如何删除用户?

Oracle中使用DROP USER来删除用户,如果使用DROP USER CASCADE那么用户的对象也同时被删除掉。为了达到删除用户的效果而又不影响对用户下的对象的使用可以使用alter user username account lock将用户锁定。

 

13、简述ORACLE中SGA的组成部分。

系统全局区包括:共享池、重做日志缓存区、数据高速缓存区,大池,JAVA池。

 

14、在Oracle表空间的分类和作用,如排序时数据将放在什么表空间?

作用是为了突破存储容量的限制,是一个逻辑概念。排序数据放在临时表空间。

 

15、用命令创建用户,并为用户授权。

Create user user_name

identified by password /

identified externally/

identified blobally as ‘CN=user’

default tablespace tablespace_name

temporary tablespace tablespace_name;

grant role/privilege to user_name;

 

16、在Oracle中,如何查看当前用户下的所有表空间?

Select tablespace_name from user_tablespaces;

 

17、在Oracle中,你所创建的表空间信息放在哪里?

存放在数据字典中,数据字典内容对应于系统表空间SYSTEM表空间。

 

18、ORACLE中的控制文件什么时候读取?

ORACLE服务器启动时,先启动实例然后再读取数据库的各个文件当然也包括控制文件。也就是说在数据库服务器启动的第二步时读取。

 

19、Oracle的表格信息存储在哪个地方?

SYSTEM表空间的数据字典文件中。

 

20、简述Oracle的归档与不归档工作模式,分别说明。

Oracle归档模式是指在创建数据库时指定了ARCHIVELOG参数,这种模式下,当重做日志文件写满的时候会将该重做日志文件的内容保存到指定的位置

(由初始化文件中的参数ARCHIVE_LOG_DEST_n来决定)。并不是数据库在归档模式下工作的时候就可以自动完成归档操作,在归档模式下可以有两种归档方式:自动归档(在初始化文件中的参数ARCHIVE_LOG_START被设置为TRUE)和手动归档。如果归档模式下没有启动自动归档的话,而且又没有实行手动归档那么当LGWR进程将重做日志信息写入已经写满的重做日志文件时数据库将会被挂起直到进行了归档。可见归档是对重做日志文件信息的一种保护措施。

Oracle非归档模式下当重做日志文件写满以后若是有LGWR进行重做日志信息的写入操作时,以前保存在重做日志文件中的重做日志信息就会被覆盖掉。

 

21、控制文件都含有哪些信息?

控制文件存放有实例信息(实例名称创建时间等),数据文件和日志文件信息,还有系统运行时记录的系统变更码(SCN),检查点信息和归档的当前状态信息等。数据库在加载数据库的时候首先要读取控制文件获得和数据库有关的物理结构信息之后才能够正确加载数据文件和日志文件并打开数据库。

 

22、表空间如何扩展?并用语句写出?

两种扩展方式:

a)增加数据文件

alter tablespace tablespace_name add datafile ‘’ xxMB

b)扩展数据文件大小

alter database datafile ‘’ resize newMB

 

23、表空间区管理方式?哪种方式现在是推荐使用的?

a)字典管理方式

extent management dictionary;默认方式

b)本地管理方式

extent management local[autoallocate/uniform xxmb];

 

24、常发生的异常有哪些?

常用预定义例外

CURSOR_ALREADY_OPEN — ORA-06511 SQLCODE = -6511 游标已经打开

DUP_VAL_ON_INDEX — ORA-00001 SQLCODE = -1 违反唯一性约束

INVALID_CURSOR — ORA-01001 SQLCODE = -1001 非法游标操作

INVALID_NUMBER — ORA-01722 SQLCODE = -1722 字符向数字转换失败

LOGIN_DENIED — ORA-01017 SQLCODE = -1017

NO_DATA_FOUND — ORA-01403 SQLCODE = +100 没有找到数据

NOT_LOGGED_ON — ORA-01012 SQLCODE = -1012 没有连接到数据库

PROGRAM_ERROR — ORA-06501 SQLCODE = -6501 内部错误

STORAGE_ERROR — ORA-06500 SQLCODE = -6500

TIMEOUT_ON_RESOURCE — ORA-00051 SQLCODE = -51

TOO_MANY_ROWS — ORA-01422 SQLCODE = -1422 返回多行

TRANSACTION_BACKED_OUT — ORA-00061 SQLCODE = -61

VALUE_ERROR — ORA-06502 SQLCODE = -6502 数值转换错误

ACCESS_INTO_NULL试图为NULL对象的属性赋值

ZERO_DIVIDE — ORA-01476 SQLCODE = -1476 被零除

OTHERS — 其它任何错误的处理 

 

25、如何使用异常?

在oracle中有三种类型的异常。预定义的异常 非预定义的异常 用户定义的异常 第二种非预定义的异常是与特定的oracle错误关联。并且用PRAGM EXCEPTION_INIT(EXCEPTION_NAME,ERROR_NUMBER)关联一起的。但是到底有什么用啊? 例如:declare dup_primary_key exception; pragma exception_init(dup_primary_key,-1); begin insert into itemfile values(‘i201′,’washer’,'spares’,100,50,250,12,30); exception when dup_primary_key then dbms_output.put_line(‘重复项编号-主键冲突’); end

第一种的使用方法:exception

when 异常名称 then

异常处理代码;

第三种的用法:if 条件 then

raise_application_error(-20000“““`-20999,提示信息);

end if;

 

26、 rowid, rownum的定义 

rowid和rownum都是虚列 

rowid是物理地址,用于定位oracle中具体数据的物理存储位置 

rownum则是sql的输出结果排序。 

 

27、oracle中存储过程,游标和函数的区别 

游标类似指针,游标可以执行多个不相关的操作.如果希望当产生了结果集后,对结果集中的数据进行多 种不相关的数据操作 

函数可以理解函数是存储过程的一种; 函数可以没有参数,但是一定需要一个返回值,存储过程可以没有参数,不需要返回值;两者都可以通过out参数返回值, 如果需要返回多个参数则建议使用存储过程;在sql数据操纵语句中只能调用函数而不能调用存储过程 

 

28、Oracle是怎样分页的

Oracle用rownum进行分页

分页语句的步骤:

a.最内层sql,查询要分页的所有数据

b.第二层sql,通过rownum伪列确定显示数据的上限,并且给查询的数据添加rownum伪列的值

c.最外层sql,设置显示数据的下限

select*from

(select a.*,rownum r from

(select*from表名 where条件 orderby列) a

whererownum<=页数*条数) b where r>(页数-1)*条数

 

29、Oracle中的rownum不能使用大于>的问题

   关于Oracle 的 rownum 问题,很多资料都说不支持SQL语句中的“>、>=、=、between...and”运算符,只能用如下运算符号“<、<=、!=”,

   并非说用“>、>=、=、between..and”时会提示SQL语法错误,而是经常是查不出一条记录来,还会出现似乎是莫名其妙的结果来。

   其实,只要理解好了这个 rownum 伪列的意义就不应该感到惊奇。

   rowid 与 rownum 虽都被称为伪列,但它们的存在方式是不一样的:

   rowid 是物理存在的,表示记录在表空间中的唯一位置ID,在DB中是唯一的。只要记录没被搬动过,rowid是不变的。

   rowid 相对于表来说又像表中的一般列,所以,以 rowid 为条件就不会有rownum那些莫名其妙的结果出现。

   另外还要注意:rownum不能以任何基表的名称作为前缀。

   对于下面的SQL语句

   SQL>select rownum,id,age,name from loaddata where rownum > 2;

    ROWNUM ID     AGE NAME

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

    rownum>2,没有查询到任何记录。

    因为rownum总是从1开始的,第一条不满足去掉的话,第二条的rownum 又成了1。依此类推,所以永远没有满足条件的记录。

    可以这样理解:rownum是一个序列,是Oracle数据库从数据文件或缓冲区中读取数据的顺序。

    它取得第一条记录则rownum值为1,第二条为2。依次类推。

    当使用“>、>=、=、between...and”这些条件时,从缓冲区或数据文件中得到的第一条记录的rownum为1,不符合sql语句的条件,会被删除,接着取下条。

    下条的rownum还会是1,又被删除,依次类推,便没有了数据。

 

30、主键有几种

复合型、整数型、字符型

 

31、SQL语句与SQL*PLUS命令的区别

1)SQL是关系型数据库的标准操作语言,而SQL*PLUS是一个客户端工具,除了执行标准的SQL外,还可以执行工具本身的一些命令。

2)SQL语句不可以缩写,而SQL*PLUS命令可以缩写

 

32、MySQL数据库与Oracle数据库有什么区别

1)应用方面:MySQL是中小型应用的数据库,一般用于个人项目或中小型网站及论坛。Oracle属于大型数据库,一般在具有相当规模的企业应用。

2)自动增长的数据类型方面:MySQL有自动增长的数据类型。Oracle没有自动增长的数据类型,需要建立一个自增序列

3)group by用法:MySQL中group by在select语句中可以随意使用,但是在Oracle中如果查询语句中有组函数,那其他列名必须是组函数处理过的或者是group by子句中的列,否则报错

4)引号方面:MySQL中用双引号包起字符串,Oracle中只可以用单引号包起字符串

 

33、oracle的锁又几种,定义分别是什么

1.  行共享锁 (ROW SHARE) 

2.  行排他锁(ROW EXCLUSIVE) 

3 . 共享锁(SHARE) 

4.  共享行排他锁(SHARE ROW EXCLUSIVE) 

5.  排他锁(EXCLUSIVE) 

使用方法: 

SELECT * FROM order_master WHERE vencode="V002"  FOR UPDATE WAIT 5; 

LOCK TABLE order_master IN SHARE MODE; 

LOCK TABLE itemfile IN EXCLUSIVE MODE NOWAIT; 

 

ORACLE锁具体分为以下几类: 

1.按用户与系统划分,可以分为自动锁与显示锁 

自动锁:当进行一项数据库操作时,缺省情况下,系统自动为此数据库操作获得所有有必要的锁。 

显示锁:某些情况下,需要用户显示的锁定数据库操作要用到的数据,才能使数据库操作执行得更好,显示锁是用户为数据库对象设定的。 

 

2 . 按锁级别划分,可分为共享锁与排它锁 

共享锁:共享锁使一个事务对特定数据库资源进行共享访问——另一事务也可对此资源进行访问或获得相同共享锁。共享锁为事务提供高并发性,但如拙劣的事务设计+共享锁容易造成死锁或数据更新丢失。 

排它锁:事务设置排它锁后,该事务单独获得此资源,另一事务不能在此事务提交之前获得相同对象的共享锁或排它锁。 

 

3.按操作划分,可分为DML锁、DDL锁 

DML锁又可以分为,行锁、表锁、死锁 

行锁:当事务执行数据库插入、更新、删除操作时,该事务自动获得操作表中操作行的排它锁。 

表级锁:当事务获得行锁后,此事务也将自动获得该行的表锁(共享锁),以防止其它事务进行DDL语句影响记录行的更新。事务也可以在进行过程中获得共享锁或排它锁,只有当事务显示使用LOCK TABLE语句显示的定义一个排它锁时,事务才会获得表上的排它锁,也可使用LOCK TABLE显示的定义一个表级的共享锁(LOCK TABLE具体用法请参考相关文档)。 

死锁:当两个事务需要一组有冲突的锁,而不能将事务继续下去的话,就出现死锁。 

如事务1在表A行记录#3中有一排它锁,并等待事务2在表A中记录#4中排它锁的释放,而事务2在表A记录行#4中有一排它锁,并等待事务; 1在表A中记录#3中排它锁的释放,事务1与事务2彼此等待,因此就造成了死锁。死锁一般是因拙劣的事务设计而产生。死锁只能使用SQL下:alter system kill session "sid,serial#";或者使用相关操作系统kill进程的命令,如UNIX下kill -9 sid,或者使用其它工具杀掉死锁进程。 

DDL锁又可以分为:排它DDL锁、共享DDL锁、分析锁 

排它DDL锁:创建、修改、删除一个数据库对象的DDL语句获得操作对象的 排它锁。如使用alter table语句时,为了维护数据的完成性、一致性、合法性,该事务获得一排它DDL锁。 

共享DDL锁:需在数据库对象之间建立相互依赖关系的DDL语句通常需共享获得DDL锁。 

如创建一个包,该包中的过程与函数引用了不同的数据库表,当编译此包时,该事务就获得了引用表的共享DDL锁。 

分析锁:ORACLE使用共享池存储分析与优化过的SQL语句及PL/SQL程序,使运行相同语句的应用速度更快。一个在共享池中缓存的对象获得它所引用数据库对象的分析锁。分析锁是一种独特的DDL锁类型,ORACLE使用它追踪共享池对象及它所引用数据库对象之间的依赖关系。当一个事务修改或删除了共享池持有分析锁的数据库对象时,ORACLE使共享池中的对象作废,下次在引用这条SQL/PLSQL语句时,ORACLE重新分析编译此语句。 

4.内部闩锁 

内部闩锁:这是ORACLE中的一种特殊锁,用于顺序访问内部系统结构。当事务需向缓冲区写入信息时,为了使用此块内存区域,ORACLE首先必须取得这块内存区域的闩锁,才能向此块内存写入信息。 

 

 

34、Oracle中function和procedure的区别? 

1). 可以理解函数是存储过程的一种 

2). 函数可以没有参数,但是一定需要一个返回值,存储过程可以没有参数,不需要返回值 

3). 函数return返回值没有返回参数模式,存储过程通过out参数返回值, 如果需要返回多个参数则建议使用存储过程 

4). 在sql数据操纵语句中只能调用函数而不能调用存储过程

 

35、Oracle的导入导出有几种方式,有何区别? 

1). 使用oracle工具 exp/imp 

2). 使用plsql相关工具 

方法1. 导入/导出的是二进制的数据, 2.plsql导入/导出的是sql语句的文本文件 

 

36、Oracle中字符串用什么符号链接? 

Oracle中使用 || 这个符号连接字符串 如 ‘abc’ || ‘d’ 

 

37、Oracle分区是怎样优化数据库的? 

Oracle的分区可以分为:列表分区、范围分区、散列分区、复合分区。 

1).  增强可用性:如果表的一个分区由于系统故障而不能使用,表的其余好的分区仍可以使用; 

2).  减少关闭时间:如果系统故障只影响表的一部份分区,那么只有这部份分区需要修复,可能比整个大表修复花的时间更少; 

3).  维护轻松:如果需要得建表,独产管理每个公区比管理单个大表要轻松得多; 

4).  均衡I/O:可以把表的不同分区分配到不同的磁盘来平衡I/O改善性能; 

5).  改善性能:对大表的查询、增加、修改等操作可以分解到表的不同分区来并行执行,可使运行速度更快 

6).  分区对用户透明,最终用户感觉不到分区的存在。

 

38、Oralce怎样存储文件,能够存储哪些文件? 

Oracle 能存储 clob、nclob、 blob、 bfile 

Clob  可变长度的字符型数据,也就是其他数据库中提到的文本型数据类型 

Nclob 可变字符类型的数据,不过其存储的是Unicode字符集的字符数据 

Blob  可变长度的二进制数据 

Bfile  数据库外面存储的可变二进制数据 

 

39、Oracle中使用了索引的列,对该列进行where条件查询、分组、排序、使用聚集函数,哪些用到了索引? 

均会使用索引, 值得注意的是复合索引(如在列A和列B上建立的索引)可能会有不同情况 

 

40、数据库怎样实现每隔30分钟备份一次? 

通过操作系统的定时任务调用脚本导出数据库

 

41、Oracle中where条件查询和排序的性能比较? 

Order by使用索引的条件极为严格,只有满足如下情况才可以使用索引, 

1). order by中的列必须包含相同的索引并且索引顺序和排序顺序一致 

2). 不能有null值的列 

所以排序的性能往往并不高,所以建议尽量避免order by

 

42、解释冷备份和热备份的不同点以及各自的优点? 

冷备份发生在数据库已经正常关闭的情况下,将关键性文件拷贝到另外位置的一种说法 

热备份是在数据库运行的情况下,采用归档方式备份数据的方法 

冷备的优缺点: 

1).是非常快速的备份方法(只需拷贝文件)  

2).容易归档(简单拷贝即可)  

3).容易恢复到某个时间点上(只需将文件再拷贝回去)  

4).能与归档方法相结合,作数据库“最新状态”的恢复。  

5).低度维护,高度安全。  

冷备份不足:  

1).单独使用时,只能提供到“某一时间点上”的恢复。  

2).在实施备份的全过程中,数据库必须要作备份而不能作其它工作。也就是说,在冷备份过程中,数据库必须是关闭状态。  

3).若磁盘空间有限,只能拷贝到磁带等其它外部存储设备上,速度会很慢。  

4).不能按表或按用户恢复。  

 

热备的优缺点 

1).可在表空间或数据文件级备份,备份时间短。  

2).备份时数据库仍可使用。  

3).可达到秒级恢复(恢复到某一时间点上)。  

4).可对几乎所有数据库实体作恢复。  

5).恢复是快速的,在大多数情况下在数据库仍工作时恢复。  

热备份的不足是:  

  1).不能出错,否则后果严重。  

  2).若热备份不成功,所得结果不可用于时间点的恢复。  

  3).因难于维护,所以要特别仔细小心,不允许“以失败而告终”。 

 

43、解释data block , extent 和 segment的区别? 

data block 数据块,是oracle最小的逻辑单位,通常oracle从磁盘读写的就是块 

extent 区,是由若干个相邻的block组成 

segment段,是有一组区组成 

tablespace表空间,数据库中数据逻辑存储的地方,一个tablespace可以包含多个数据文件 

 

44、解释什么是死锁,如何解决Oracle中的死锁? 

简言之就是存在加了锁而没有解锁,可能是使用锁没有提交或者回滚事务,如果是表级锁则不能操作表,客户端处于等在状态,如果是行级锁则不能操作锁定行 

解决办法: 

1). 查找出被锁的表 

select b.owner,b.object_name,a.session_id,a.locked_mode 

from v$locked_object a,dba_objects b 

where b.object_id = a.object_id; 

     

select b.username,b.sid,b.serial#,logon_time 

from v$locked_object a,v$session b 

where a.session_id = b.sid order by b.logon_time; 

2). 杀进程中的会话 

alter system kill session "sid,serial#"; 

 

45. 简述oracle中 dml、ddl、dcl的使用 

Dml 数据操纵语言,如select、update、delete,insert 

Ddl 数据定义语言,如create table 、drop table 等等 

Dcl 数据控制语言, 如 commit、 rollback、grant、 invoke等 

 

46、说说oracle中的经常使用到得函数 

Length 长度、 lower 小写、upper 大写, to_date 转化日期, to_char转化字符 

Ltrim 去左边空格、 rtrim去右边空格,substr取字串,add_month增加或者减掉月份、to_number转变为数字 

 

47、存储过程有什么好处? 

存储过程优缺点: 

优点: 

1. 存储过程增强了SQL语言的功能和灵活性。存储过程可以用流控制语句编写,有很强的灵活性,可以完成复杂的判断和较复杂的运算。 

2. 可保证数据的安全性和完整性。 

3. 通过存储过程可以使没有权限的用户在控制之下间接地存取数据库,从而保证数据的安全。 

      通过存储过程可以使相关的动作在一起发生,从而可以维护数据库的完整性。 

3. 再运行存储过程前,数据库已对其进行了语法和句法分析,并给出了优化执行方案。这种已经编译好的过程可极大地改善SQL语句的性能。 由于执行SQL语句的大部分工作已经完成,所以存储过程能以极快的速度执行。 

4. 可以降低网络的通信量, 不需要通过网络来传送很多sql语句到数据库服务器了 

5. 使体现企业规则的运算程序放入数据库服务器中,以便集中控制 

       当企业规则发生变化时在服务器中改变存储过程即可,无须修改任何应用程序。企业规则的特点是要经常变化,如果把体现企业规则的运算程序放入应用程序中,则当企业规则发生变化时,就需要修改应用程序工作量非常之大(修改、发行和安装应用程序)。如果把体现企业规则的 运算放入存储过程中,则当企业规则发生变化时,只要修改存储过程就可以了,应用程序无须任何变化。 

缺点: 

1. 可移植性差 

2. 占用服务器端多的资源,对服务器造成很大的压力 

3. 可读性和可维护性不好 

 

48、VarChar和VarChar2的区别

varchar       存放固定长度的字符数据,最长2000个字符。

varchar2    存放可变长字符数据,最大长度为4000字符。,最大長度為4000字符。

varchar     是标准sql提供的数据类型。

varchar2  是oracle提供的独特的数据类型。

oracle保证在任何版本中该数据类型向上和向下兼容,但不保证varchar。

总之,如果想新版本的数据库兼容就不要用varchar,如果想和其他数据库兼容就不要用varchar2。

 

49、使用oracle 伪列删除表中重复记录: 

Delete  table t  where t.rowid!=(select  max(t1.rowid)  from  table1 t1 where  t1.name=t.name)

 

50、Ocale区分大小写吗?

用Oracle的GUI工具创建数据库表时 给表名称加上双引号,则表名称区分大小写,如果输入包含小写字母,再用时,也必须加上双引号来区分大小写;如果输入的均为大写字母,则创建的和不加引号创建的表名一样,原因Oracle中SQL语句中输入的串默认均被系统转换为大写,加引号后则系统不进行大写转换。 

 

 

 

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值