有些Oracle对于新的平台来说是一些棘手的问题,但对于关系型数据库( MySQL,MS sql Server,Postgres等)来说并不是新鲜事.

我正在寻找的事情的两个例子

>许多关系数据库产品处理为您创建一个auto_increment密钥. Oracle不会,您必须手动创建序列,然后创建触发器
>当通过sql Developer界面插入数据时,必须手动提交数据

PHP相关的积分奖励,因为这是这个假设经验的newb将使用的平台.

注意:我只是在这里解释问题,即Oracle的行为不如其他系统那样. Oracle与其他RDBMS相比有许多优点,但它们不是该主题.

>你不能没有FROM SELECT.

SELECT  1

将失败,您需要:

SELECT  1
FROM    dual

>空字符串和NULL是一样的.

SELECT  *
FROM    dual
WHERE   '' = ''

没有回报.
>没有TOP或LIMIT.您将结果限制在WHERE子句中:

SELECT  *
FROM    (
        SELECT  *
        FROM    mytable
        ORDER BY
                col
        )
WHERE   rownum < 10

正是这样,使用子查询,因为ROWNUM在ORDER BY之前被评估.
>您无法将相关子查询嵌套多于一个级别.这将失败:

SELECT  (
        SELECT  *
        FROM    (
                SELECT  dummy
                FROM    dual di
                WHERE   di.dummy = do.dummy
                ORDER BY
                        dummy
                )
        WHERE   rownum = 1
        )
FROM    dual do

这是个问题.
> NULL值不被索引.此查询将不会使用索引进行排序:

SELECT  *
FROM    (
        SELECT  *
        FROM    mytable
        ORDER BY
                col
        )
WHERE   rownum < 10

,除非col被标记为NOT NULL.

注意,它不是没有索引的NULL值,而不是列.您可以在可空列中创建索引,非NULL值将进入索引.

但是,当查询条件假定NULL值可能满足它时,索引将不会被使用.

在上面的示例中,您希望返回所有值(包括NULL).那么索引不知道非NULL值,因此无法检索它们.

SELECT  *
FROM    (
        SELECT  *
        FROM    mytable
        ORDER BY
                col
        )
WHERE   rownum < 10

但这个查询将使用索引:

SELECT  *
FROM    (
        SELECT  *
        FROM    mytable
        WHERE   col IS NOT NULL
        ORDER BY
                col
        )
WHERE   rownum < 10

,因为非NULL值不能满足条件.
>默认情况下,NULL最后排序,而不是首先(如Postgresql中,但与MysqL和sql Server不同)

这个查询:

SELECT  *
FROM    (
        SELECT  1 AS id
        FROM    dual
        UNION ALL
        SELECT  NULL AS id
        FROM    dual
        ) q
ORDER BY
        id

将返回

id
---
1
NULL

要像sql Server和MysqL一样排序,请使用:

SELECT  *
FROM    (
        SELECT  1 AS id
        FROM    dual
        UNION ALL
        SELECT  NULL AS id
        FROM    dual
        ) q
ORDER BY
        id NULLS FirsT

请注意,除非后者没有从子查询中使用,否则它会破坏rownum顺序(如上所述)
>“MYTABLE”和“mytable”(双引号)是不同的对象.

SELECT  *
FROM    mytable -- wihout quotes

将从前者中选出,而不是后者.如果前者不存在,查询将失败.

CREATE TABLE mytable

创建“MYTABLE”而不是“mytable”.
>在Oracle中,所有隐式锁(由DML操作产生的)都是行级,并且不会升级.那就是没有行不受事务的影响可以隐式锁定.

作家绝对不会阻止读者(反之亦然).

要锁定整个表,您应该发出一个显式的LOCK TABLE语句.

行锁存储在数据页上.
>在Oracle中,没有“CLUSTERED索引”,有“索引组织表”.默认情况下,表是堆组织的(与InnoDB不同的是sql Server和MysqL).

在Oracle世界中,“集群存储”意味着组织几个表,以便共享公共密钥(来自多个表)的行也共享一个数据页.

单个数据页可以从多个表中托管多个行,这使得该键上的连接超级快速.

php – Oracle Gotchas for a Experienced Newb的更多相关文章

  1. HTML5、Select下拉框右边加图标的实现代码(增进用户体验)

    这篇文章主要介绍了HTML5、Select下拉框右边加图标的实现代码,深度美化页面增进用户体验效果,需要的朋友可以参考下

  2. 在Sierra上,Brew安装错误单独使用Xcode是不够的

    我正在尝试使用HomeBrewv1.3.8在运行xCodev9.1的MacOSXSerrav10.12.6上安装软件包.安装和错误是然后我运行命令表示软件更新服务器无法使用命令行工具包.我进入xCode,它表明安装了命令行工具.任何帮助将非常感激.西奥解决方法我去了AppleDeveloper网站并直接下载了命令行工具dmg.首先需要设置Apple帐户.命令行工具可在以下位置找到–https://

  3. ios – 如何在swift3中增加String.Index?

    在swift2.3中运算符用于string.index增加例如.一世我改为swift3代码发生了“一元运算符”不能应用于’@valueString.Index’类型的操作数(又名’@lvalueString.CharacterView.Index’)“在swift3中我改写了例如.i=1但是这段代码无法解决.请帮我.解决方法String.Index是String.CharacterView.Ind

  4. ios – CoreData有序关系 – 使用NSFetchRequest批量取消

    或者,是否存在批量不支持的API,它不是私有的?解决方法目前我有一个解决方案,但不是一个干净的解决方案:我希望按照有序关系中的20个小组进行批量修改.所以,每次我索引一个索引,它的索引除以20,我为接下来的20使用新的NSFetchRequest,并通过调用公共字段名称来解除它们.

  5. iOS 10 Safari问题在DOM中不再包含元素

    使用此链接,您可以重现该错误.https://jsfiddle.net/pw7e2j3q/如果您点击元素并从dom中删除它,然后单击链接测试.你应该看到旧的元素弹出选择.是否有一些黑客来解决这个问题?解决方法我能够重现这个问题.问题是,每当您尝试删除其更改事件上的选择框时,iOS10都无法正确解除对选择框的绑定.要解决此问题,您需要将代码更改事件代码放在具有一些超时

  6. iOS Chrome上的HTML SELECT不显示“完成”选项

    我们在iOS上的Chrome中使用UI呈现时遇到问题,特别是HTMLSELECTDropDown元素.例:使用Safari,当您点击SELECT时,屏幕底部会打开一个微调器–您可以点击完成以选择您的选择并返回到表单.但是,当您在iOS上的Chrome中加载完全相同的页面时,不会显示“完成”.用户必须选择他们的选择,然后点击UI上的其他位置返回到表单.非常不直观,用户感觉好像SELECT没有用.有人有解决方案吗?

  7. 安装命令行工具Xcode 5

    我已经尝试过并尝试过但我仍然无法解决问题.我正在尝试安装PebbleSDK1.12并安装Xcode5的命令行工具.每次我在终端尝试xcode-select–install时,我都会收到“无法安装软件,因为它目前在软件更新服务器中不可用”我试图重新安装Xcode,但是没有用.当我进入Xcode-preferences-downloads时,没有命令行工具的部分.我也试过从开发者网站安装它们但无济于事.下载看起来正确,然后我去Xcode看到首选项,并没有列出命令行工具.你们都能提出什么建议吗?

  8. ios – Swift中的PageViewController当前页面索引

    我想获取一个pageViewController的当前索引,我不知道我如何获取可见页索引.解决方法您可以使用didFinishAnimating,并将标签设置为查看控制器.尝试这个

  9. ios – xcodebuild相当于Xcode的“产品&gt;构建&gt;测试”

    我正在尝试编写一个脚本,将iOS应用程序提交给AppThwack(一个“真正的设备”UI测试服务).他们的指导是使用XcodeGUI,并使用BuildFor>Xcode产品菜单中的测试选项.这是有效的,但我无法将其转换为xcodebuild等效项.更一般地说,我们如何确定Xcode传递给xcodebuild的什么参数(假设它使用该工具).解决方法现在可以从Xcode8开始(在写作时在beta版).

  10. ios – OpenGL – 为什么GL_ELEMENT_ARRAY_BUFFER的索引?

    我目前是OpenGLES2.0领域的新手,希望尽可能地了解绑定,缓冲区,着色器等.截至目前,我只是想了解GL_ELEMENT_ARRAY_BUFFER和GL_ARRAY_BUFFER之间的差异,以及何时使用每个注释的预设.我目前的理解使我相信GL_ELEMENT_ARRAY_BUFFER是专门用于所述三角形的索引,而另一个则是其他的.有人可以详细说明为什么,如果这是正确的?GL_ELEMENT_A

随机推荐

  1. PHP个人网站架设连环讲(一)

    先下一个OmnihttpdProffesinalV2.06,装上就有PHP4beta3可以用了。PHP4给我们带来一个简单的方法,就是使用SESSION(会话)级变量。但是如果不是PHP4又该怎么办?我们可以假设某人在15分钟以内对你的网页的请求都不属于一个新的人次,这样你可以做个计数的过程存在INC里,在每一个页面引用,访客第一次进入时将访问时间送到cookie里。以后每个页面被访问时都检查cookie上次访问时间值。

  2. PHP函数学习之PHP函数点评

    PHP函数使用说明,应用举例,精简点评,希望对您学习php有所帮助

  3. ecshop2.7.3 在php5.4下的各种错误问题处理

    将方法内的函数,分拆为2个部分。这个和gd库没有一点关系,是ecshop程序的问题。会出现这种问题,不外乎就是当前会员的session或者程序对cookie的处理存在漏洞。进过本地测试,includes\modules\integrates\ecshop.php这个整合自身会员的类中没有重写integrate.php中的check_cookie()方法导致,验证cookie时返回的username为空,丢失了登录状态,在ecshop.php中重写了此方法就可以了。把他加到ecshop.php的最后面去就可

  4. NT IIS下用ODBC连接数据库

    $connection=intodbc_connect建立数据库连接,$query_string="查询记录的条件"如:$query_string="select*fromtable"用$cur=intodbc_exec检索数据库,将记录集放入$cur变量中。再用while{$var1=odbc_result;$var2=odbc_result;...}读取odbc_exec()返回的数据集$cur。最后是odbc_close关闭数据库的连接。odbc_result()函数是取当前记录的指定字段值。

  5. PHP使用JpGraph绘制折线图操作示例【附源码下载】

    这篇文章主要介绍了PHP使用JpGraph绘制折线图操作,结合实例形式分析了php使用JpGraph的相关操作技巧与注意事项,并附带源码供读者下载参考,需要的朋友可以参考下

  6. zen_cart实现支付前生成订单的方法

    这篇文章主要介绍了zen_cart实现支付前生成订单的方法,结合实例形式详细分析了zen_cart支付前生成订单的具体步骤与相关实现技巧,需要的朋友可以参考下

  7. Thinkphp5框架实现获取数据库数据到视图的方法

    这篇文章主要介绍了Thinkphp5框架实现获取数据库数据到视图的方法,涉及thinkPHP5数据库配置、读取、模型操作及视图调用相关操作技巧,需要的朋友可以参考下

  8. PHP+jquery+CSS制作头像登录窗(仿QQ登陆)

    本篇文章介绍了PHP结合jQ和CSS制作头像登录窗(仿QQ登陆),实现了类似QQ的登陆界面,很有参考价值,有需要的朋友可以了解一下。

  9. 基于win2003虚拟机中apache服务器的访问

    下面小编就为大家带来一篇基于win2003虚拟机中apache服务器的访问。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  10. Yii2中组件的注册与创建方法

    这篇文章主要介绍了Yii2之组件的注册与创建的实现方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下

返回
顶部