oracle的毛病!!

oracle

本文纯为牢骚, 怨言。一为笔者对ORACLE软件如此这般的疑惑与不满,
二来其实可以总结ORACLE中的一些不规则性, 为ORACLE学习者提供一些借鉴..

1. 改变当前用户时SQLPLUS环境变量的设置是否被继承到新的用户环境下
  混乱, serverout 没有被继承, 而pagesize被继承.
2. SQLPLUS环境下命令行编辑功能微弱得可怜, 看看readline, 看看MySQL
3. SQLPLUS环境的命令行没有历史记录功能, 看看MySQL. gdb, bash
4. 命名规范混乱得一踏糊涂. user_tab_columns, user_con_constraints
  user_tables, usre_cons_columns
5. SQLPLUS环境的初始化文件的location的要求, 看看.bashrc, .vimrc, .netrc
  .emacs, .newsrc...摸一个都比它强, 我要使用你的login.sql还非得在每
  一个当前目录下都弄一份, 随身携带呀? 好在这一点可以通过SQLPATH环境
  变量的设置来搞定.
6. 注释格式:--, 什么玩意呀, HTML用, perl用#, php用#或/**/或
  //, C用/**/, C++用/**/和//, lisp用;;, 汇编用;, QBASIC用rem 和',
  SHELL,SED,AWK用#, 你干吗要自创一种. 自以为很鸟啊, 与别人兼容一点会
  小你什么身份.
7. 看看它的PL/SQL, 号称第N代的高级语言, function因为必需返回一个值而
  存在, 除此之外我看不出它与其它的procedure有什么区别. 又是trigger,
  又是package, 又是procedure, 又是function, 搞什么东东呀. 别人是把
  复杂的东西简单化, 我看ORACLE是要把简单的东西复杂化, 同样是PL/SQL
  程序, dbms_output.put_line被设计成在function里单独调用时不能输出.
  非要一个procedure单独调用它时它才会输出.
8. 单引号问题, Javascript可以兼容使用单双引号, perl可以, php也可以, 它
  们可以是因为它们想兼容, 想对用户友好, C语言不允许, 那是因为它严谨.
  人家留着有大用场. 你ORACLE不允许使用双引号又是什么原由, 说来听听.
9. 别人的用户界面设计是"没有消息就是最好的消息", 或是"无论发生什么, 都
  要让用户知道", 看看它在sqlplus下的变量:
  var i number;
  i:=5;
  print i;
  你什么看见什么, 什么都没有! 你又能从这知道什么, 好消息?
  PS:我至今都不知道这说明了什么? i的值为NULL?, i不能在这下面赋值?
  不能赋值你说呀, 你不说我怎么知道不能赋值, 虽然你很能有意见地显示了
  一个空行, 但是你还是要说呀, 你真的不能赋值吗? 你不是真的不能赋值吧?
  ...
  后记: 好在我今天知道了要用
  SQL> exec :i := 5;
  SQL> print :i
  但总不能让我掘地三尺才找得出来这些浅显的东西吧.
10. 在sqlplus下help set看看, 找出一个叫set severout[put] on|off的选项
  注意, 它是severout, 你在sqlplus下set severout on试试,
  SP2-0158: unknown SET option "severout" 了吧?
  set serverout on
  是的, 就一个字母而已.
  编程大师说: 任何软件都有BUG.
  但, 一个如此小的BUG可以让一个全球第二大的软件公司带着它走过几个版本?
  Oracle8.15 Oracle8.16 Oracle8.17...难道保留错误是为了兼容性?
  后记: 我终于看到Oracle9i版里对此有了改进, 略感欣慰.

时间: 2024-10-29 08:45:35

oracle的毛病!!的相关文章

用IE登录Linux服务器上的em出现的乱码的解决

linux服务器|解决 用IE登录Linux服务器上的em出现的乱码的解决 作者: Fenng 问题描述 在Linux(Unix)环境下成功安装了Oracle 10g,从windows下用IE浏览器登录 10g 的em, 按钮是"口口"这样的方框. 解决办法 其实严格的说来,这是Java的问题.JDK Swing采用TrueType 字体作为按钮的显示字体,如果你的JDK 找不到中文字体用来显示,你看到的一些按钮就变成小方块的样子. 一般情况下, 我们只需要修改相应的 font.pro

oracle毛病(二)

oracle 接第一篇:11. PL/SQL的用户们, 看看下面: 创建一个没带参数的procedure: create or replace procedure proc_name as i number; begin ... end proc_name; 创建一个带参数的procedure: create or replace procedure proc_name(arg1,...) as i number; begin ... end proc_name; 你很习惯用declare来声明

Oracle数据安全面面观(二)

oracle|安全|数据 (二)来自内部的另外一个隐患--用户管理以及密码问题     在这里,其实作为一个差不多点的数据库管理员都很清楚,Oracle数据库本身就使用了很多种手段来加强数据库的安全性,经常见到的就有密码,角色,权限等等.那么我们就从最简单的DBSNMP说起:     Oralce数据库如果采用典型安装后,自动创建了一个叫做DBSNMP的用户,该用户负责运行Oracle系统的智能代理(Intelligent Agent),该用户的缺省密码也是"DBSNMP".如果忘记修

在Adaptive Server Anywhere和Oracle之间构造通用函数

oracle|server|函数 在Adaptive Server Anywhere和Oracle之间构造通用函数辽河油田锦采地质大队 邓先永 01-7-2 上午 10:29:41 在使用PowerBuilder编制程序时,使用的最多的数据库接口是它自身集成的Adaptive Server Anywhere和大型数据库管理系统Oracle:有时,为了使程序的运行.移植更加方便,比如从服务器的数据管理端立即转到单机的数据管理端时,往往涉及到用户在程序的SQL语句中所使用的不同数据库平台上,函数的兼

无责任Oracle图书简评 (1)

oracle 如果现在到一家计算机书店转转,你会发现和Oracle技术相关的图书就会占据书店的很大的空间.在这些书中不乏精品,但是肯定也有一些糟粕混杂其中,对于精品,我们不妨拜读,对于那些东拼西凑的图书我们还是避而远之,免得让自己后悔. 在这里,Fenng写下对几本Oracle的图书的印象,希望能对一些朋友有个参考作用(对于Oracle技术高手可能用不到了). "无责任书评"最早在侯捷网站上看到,感觉很有意思,想想自己远没有侯先生的功力,只是凭着一些感觉,拉大旗作虎皮,这个题目也是暗示

asp.net查出oracle数据库中的中文乱码问题

把这两天两次安装IBM2650服务器中出现的问题做一个总结: 1.第一次安装,用IBM的引导盘引导,按步就班的下来,选择语言,做Raid5,选择windows系统等等 .安装好windows2003企业版之后,再去安装oracle时,安装到一半时,提示不能创建快捷方式.取消, 再安装还是不能创建快捷方式,就那样安装上了.安装之后oracle运行倒也正常,导入数据,发现中文 变成了乱码.再安装editplus和winrar发现显示窗口的中文也是乱码,右键菜单上的部分中文是乱码. 在网上搜了一下,原

《Oracle数据库性能优化方法论和最佳实践》——第1章 Oracle性能优化漫谈 1.1 从生活场景漫谈性能优化

第1章Oracle性能优化漫谈 1.1 从生活场景漫谈性能优化 Oracle数据库性能优化一直是一个让人既胆怯又兴奋的话题,在初级DBA眼里,这是一个神秘的领域,即使是资深的Oracle DBA,也可能无法描述清楚性能优化究竟要做什么,应达成什么目标.那么性能优化究竟是做什么的呢?简而言之,性能优化就是让我们的工作速度变快,快到让我们满意为止.自然,又有读者会问了,我们的工作是什么呢?什么程度才算快,是否可以衡量?看,头疼的问题又来了.1.1.1 从一个真实病例说起 下面是本人的真实经历,也许很

Oracle数据安全面面观_oracle

正在看的ORACLE教程是:Oracle数据安全面面观. Oracle数据安全面面观 作者:づ★sl战神    随着计算机的普及以及网络的发展,数据库已经不再仅仅是那些程序员所专有的话题.而Oracle数据库更是凭借其性能卓越,操作方便灵活的特点,在数据库的市场中已经占据了一席之地.但是同样随着网络技术的不断进步,数据信息的不断增加,数据安全已经不再是以前的"老生长谈",也更不是以前书本上那些"可望不可及"的条条框框.    或许很久以前,大家都觉得Oracle数据

oracle安装后打开sqlplus无法登陆

问题描述 oracle安装后打开sqlplus无法登陆 敢问这又是什么毛病啊,一天变一个问题,快疯啦.软件先装不上,还学个毛线... 64位的win8.1系统,安装时也没有什么毛病啊 解决方案 用户名直接输入:sys/密码@orcl as sysdba 解决方案二: 登录不对吧,是这样登录吗? 解决方案三: 这又是什么情况... 解决方案四: 装的是server么? 先tnsping你的tnsname,例如 tinsping orcl 看是否tns服务是否启动.如果已启动tns server,再