Access911.net   |   a9BBS   |   OTaA System  
  搜索文章:  
Access911欢迎您光临  
   主页      上传      繁體版       论坛     
设为首页  |  加入收藏   
  
你现在的位置:文章索引 -> 文章分类 -> 查询  
 首页|  近日更新|  下载  |  文章索引  |  搜索|  术语|  承接工程|  
 
系统正在加载内容,请耐心等待...
 
 查询
 窗体
 报表
 
 
 VBA
 函数
 ADO/DAO/ADO.NET
 API
 ADP
 安全
 发布
 OA
 ASP/ASP.NET
 其他语言
 控件
 DELPHI
 C#/.Net
 本站
 其他
 小例程
 常用软件
 参考文档
 业主作品
 网友大作
 
 
友情链接
 access911.net
 
访问人次
 1701915
 
站长 E-Mail
 net911@sina.com
 access911@gmail.com
 
RSS 订阅

显示附加信息 >>>

LIKE 语句到底如何组织?*和%该用哪个(二)?

作者:cg1  摘自:access911.net  :cg1  更新日期:2007-11-6  浏览人次:

 

问题:

相信大家都已经看过了

    新手来看:LIKE 语句到底如何组织?*和%该用哪个?《查询》
    http://access911.net/index.asp?u1=a&u2=72FAB31E13DCEAF3

现在我又发现了一个新的实例,蛮有意思的,大家请先下载这个数据库:
http://access911.net/down/eg/eg_sql_PercentSignOrAsterist.rar
 (30k)

窗体1的COMMAND0按钮中有一句代码调用了一个函数,大家请单击这个按钮,然后看立即窗口中的输出。
针对上述例子有网友提出了以下一个问题:
直接双击查询“97-宽带总数”有数据显示,但是在程序中用 Recordset.open 以后查 RecordCount 却是 0 ,很奇怪。

 

回答:

一开始我排查以为是嵌套了多层查询导致,但是后来只使用一个查询也出错,最后注意到查询“97-宽带未比对”中使用了 Like "*宽带*",直接修改为 Like "%宽带%" 在 ADODB.Recordset.Open 里面就有记录显示了。最终查实,还是 * % 通配符的使用环境不同导致错误。

在看这个例子的时候大家还会注意到,作者多次嵌套了基于同一个表的查询,导致以后查找错误困难,其实完全可以将多个查询合并为一句查询语句的。
SELECT FIRST(???) ???? FROM ????  WHERE ??? GROUP BY ???? HAVING ????
这样的语句应该使用一句语句完成,而不是分开嵌套3个查询。

 


另:发现911的文章质量和数量都有所下降,看来是其他软件用太多了,反思中。

本站文章旨在为该问题提供解决思路及关键性代码,并不能完成应该由网友自己完成的所有工作,请网友在仔细看文章并理解思路的基础上举一反三、灵活运用。

access911.net 原创文章,作者本人对文章保留一切权利。
如需转载必须征得作者同意并注明本站链接

 

 
相关文章
     没有手动相关文章
 
评论
     查看或发表更多的评论,请单击这里。
 
 
 
 
 
   
  Access911.net   |   a9BBS   |   OTaA System   |
建站日期:2000年4月2日  |  设计施工:陈格 ( access911 & cg1 )
 Copyright © 2000 - 2003 COMET, 陈格 保留所有权利