社区
VB
帖子详情
Oracle的语法问题,数据搜寻出来多了一倍
Jimmyliu2004
2006-02-19 10:17:11
“select a.empno, b.empname,a.mydate,a.mytime from table1.a,table2.b where a.comp='shenzhen' and a.empno=b.empno” 结果搜寻出来的数据多了一倍,本来只有10条记录的变成了20条,为什么啊??
...全文
55
1
打赏
收藏
Oracle的语法问题,数据搜寻出来多了一倍
“select a.empno, b.empname,a.mydate,a.mytime from table1.a,table2.b where a.comp='shenzhen' and a.empno=b.empno” 结果搜寻出来的数据多了一倍,本来只有10条记录的变成了20条,为什么啊??
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
1 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
fenging31
2006-02-19
打赏
举报
回复
应该是还有一个关联没有建立导致的,你查出所有的字段可能就会看出问题的。
LECCO SQL Expert (智能自动SQL优化)
更优更快 人工智能自动SQL优化----------http://www.sina.com.cn 2001/12/12 17:48 中国电脑教育报文/SQL爱好者 所谓SQL,就是指Structured Query Language(结构化查询语言),它是目前使用最广泛的
数据
库语言,用来和
数据
库打交道,从
数据
库中得到用户需要的
数据
。但是要想熟练使用SQL语句,也不是一件简单的事,有些语句使用起来也比较麻烦。如果我们对SQL语句进行优化,那么用户使用起来 就会方便许多。 简单来说,SQL语句的优化就是将性能低下的SQL语句转换成达到同样目的的性能优异的SQL语句。人工智能自动SQL优化就是使用人工智能技术,自动对SQL语句进行重写,找到性能最好的等效SQL语句。 人工智能自动SQL 优化 随着人工智能技术的发展和在
数据
库优化领域应用的深入,在20世纪90年代末终于出现了突破性的进展——人工智能自动SQL优化。目前在商用
数据
库领域LECCO TechnologyLimited(灵高公司)拥有该技术并提供使用该技术的自动优化产品——LECCO SQL Expert,其支持
Oracle
、Sybase、MS SQLServer和IBMDB2
数据
库平台。该产品针对
数据
库应用的开发和维护阶段提供了几个特别的模块:SQL
语法
优化器、PL/SQL集成化开发调试环境(IDE)、扫描器、
数据
库监视器等。图1 人工智能自动SQL优化示意图 其核心模块之一“SQL
语法
优化器”的工作原理大致如下(如图1): 一条源SQL语句输入→“人工智能反馈式搜索引擎”对输入的SQL语句结合检测到的
数据
库结构和索引进行重写,产生N条等效的SQL语句输出→产生的N条等效SQL语句再送入“人工智能反馈式搜索引擎”进行重写,直至无法产生新的输出或搜索限额满→对 输出的SQL语句进行过滤,选出具有不同执行计划的SQL语句(即不同的执行效率)→对得到的SQL语句进行批量测试,找出性能最好的SQL语句。图2 优化前的SQL语句 自动优化实例 假设我们从源代码中抽取出这条SQL语句(如图2): SELECTCOUNT(*)FROMEMPLOY-EE WHEREEXISTS(SELECT'X'FROM DEPARTMENTswheresEMP_DEPT=DPT_IDAND DPT_NAME LIKE'AC%')AND EMP_IDIN(SELECT SAL_EMP_IDFROM EMP_SAL_HISTB WHERESAL_SALARY>70000) 按“优化”按钮后,经过十几秒,SQL Expert就完成了优化的过程,从优化细节中可以看到,它在十几秒的时间内重写产生了2267条等价的SQL语句,其中136条SQL语句有不同的执行计划(如图3)。图3 优化结果 接下来我们可以对自动重写产生的136条具有不同执行计划的SQL语句进行批运行测试,以选出性能最佳的等效SQL语句。按下“批运行”按钮,在“终止条件”页选择“最佳运行时间SQL语句”(如图4),按“确定”。图4 测试条件 经过几分钟的测试运行后,我们可以发现SQL124的运行时间和反应时间最短。运行速度约有22.75倍的提升(源SQL语句运行时间为2.73秒,SQL124运行时间为0.12秒,如图5)。图5 测试结果 我们把SQL124放入源代码中,结束一条SQL语句的优化工作。从上例可以看到,LECCO SQL Expert的自动重写技术使原来需要几小时才能完成的SQL语句的优化工作,缩减到几分钟之内就可以完成。
数据
库管理员和开发人员可以从繁重的SQL语句优化工作中解脱出来。 边做边学式训练 LECCO SQL Expert不仅能够找到最佳的SQL语句,而且提供的“边做边学式训练”还能够教会开发人员和
数据
库管理员如何写出性能最好的SQL语句。LECCO SQL Expert的“SQL比较器”可以标明源SQL和待选SQL之间的不同之处。LECCO SQL Expert详尽的上下文敏感帮助系统可以指出执行计划的深层含义。图6 源语句与SQL124的比较 以上面优化的结果为例,为了查看源SQL语句和SQL124在写法上的不同,我们可以按下“比较器”按钮,对SQL124和源SQL语句进行比较。如果选择“双向比较”复选框,“SQL比较器”可以将两条互相间的不同之处以蓝色表示。当然,你也可以从 源语句和重写后的SQL语句中任选两条进行比较(如图6)。 从比较的结果可以看到,重写得到的SQL124把第一个Exists改写成了In;在字段DPT_ID上进行了合并空字符串的操作以诱导
数据
库先执行子查询中的(SELECTDPT_ID||'FROMDEPART-MENTWH
AntDB的
Oracle
语法
兼容性简单试用
AntDB是基于PG内核国内自主研发的一款开源分布式
数据
库,兼容
oracle
语法
。这里简单介绍一下使用
oracle
语法
的三种方法。 第一种:服务器级别,修改
数据
库配置文件默认为
oracle
语法
通过集群管理工具设置
语法
postgres=# set coordinator all(grammar =
oracle
); SET PARAM 设置过后,会在相应coordinator的
oracle
千万级
数据
模糊查询,
oracle
模糊查询效率拔高
分2种思路考虑模糊查询的效率的提高。--注:专注处理百万级
数据
量,小量
数据
就算了第一种:把
数据
存到业务内存中,通过查询内存提高效率。(要求:硬件内存要高)1,如果想实现内存动态
数据
,可以监控表
数据
变化更新内存。第二种:提高
oracle
数据
库的查询方式。1、使用两边加‘%’号的查询,
oracle
是不通过索引的,所以查询效率很低。例如:select count(*) from lui_user_bas...
大
数据
-玩转
数据
-
Oracle
系统知识小结
一、说明
Oracle
数据
库是甲骨文的核心产品,
Oracle
的操作都遵循sql标准,所以各个版本在基本操作方面都变化不大。
Oracle
划分在大型关系
数据
库范畴,比较Mysql或Nosql
数据
库来说,还是缺少些扩容的灵活性,但传统金融、通信、电力、航空、保险、大型企业用得比较多。 二、背景知识、
数据
建模和Linux 1.关系
数据
库 关系型
数据
库,是指采用了关系模型来组织
数据
的
数据
库,其以行和列的形式存储
数据
,以便于用户理解,关系型
数据
库这一系列的行和列被称为表,一组表组成了
数据
库。用户通过查询来检索
数据
库中
Oracle
透明
数据
加密 (TDE)常见
问题
解答
Oracle
透明
数据
加密 (TDE)常见
问题
解答
VB
16,554
社区成员
110,527
社区内容
发帖
与我相关
我的任务
VB
VB技术相关讨论,主要为经典vb,即VB6.0
复制链接
扫一扫
分享
社区描述
VB技术相关讨论,主要为经典vb,即VB6.0
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章