首页
论坛
门户
空间
手机版
IXPUB
插件
收藏
设置
注册
登录
商店
搜索
培训
Wiki
Blog
归档
丛书
退出
ITPUB论坛
»
MS SQL Server
» 请教:如何高效的达到此过滤效果
‹‹ 上一主题
|
下一主题 ››
投票
交易
悬赏
活动
评价
|
打印
|
推荐
|
订阅
|
收藏
标题:
[原创]
请教:如何高效的达到此过滤效果
icedot
初级会员
精华贴数 0
个人空间
0
技术积分 10 (88495)
社区积分 0 (718033)
注册日期 2005-12-21
论坛徽章:0
#1
使用道具
发表于 2008-7-1 22:19
请教:如何高效的达到此过滤效果
有一个数据表,其中的数据如下所示:
NO Name
1 高等数学(1)
2 高等数学(2)
3 大学语文(1)
4 大学语文(2)
5 英语
......
其中的数据有好几十万条,现在需要查询得到如下结果:
高等数学
大学语文
英语
即对于含有(1)(2)..的数据,只取第一条.
我目前采用的方法是:
select replace(Name,'(1)','') Name where (right(Name,1)<>")" ) or (right(name,3)='1')
虽然能实现功能,但感觉效率不高,请教高手,有何更好的方式(注:含有(1)(2)..这种数据占总数据量的25%左右).
只看该作者
bailiu2002
初级会员
精华贴数 0
个人空间
0
技术积分 141 (12544)
社区积分 0 (1315428)
注册日期 2007-3-25
论坛徽章:1
#2
使用道具
发表于 2008-7-1 22:52
我暈
科目總共就那么几種 需要這樣嗎?
__________________
多情自古伤离别,更那堪冷落清秋节!
今宵酒醒何处?燈火街頭,冷風殘月。
-------------------------------------------
Nothing should be taken for granted.
只看该作者
smthgdin
老会员
精华贴数 0
个人空间
0
技术积分 1319 (1285)
社区积分 1 (34698)
注册日期 2004-5-13
论坛徽章:2
#3
使用道具
发表于 2008-7-1 23:01
select distinct tt.no,tt.name from (select no,case when right(name,1)=')' then substring(name,1,len(name)-3) end as name from 表) as tt
试试这个看怎样。我觉得你的where从句性能很低。
__________________
www.kooboy.net
只看该作者
icedot
初级会员
精华贴数 0
个人空间
0
技术积分 10 (88495)
社区积分 0 (718033)
注册日期 2005-12-21
论坛徽章:0
#4
使用道具
发表于 2008-7-2 08:53
to bailiu2002
只是举的一个例子,实际数据有五十万条以上,当然有必要考虑效率问题
to smthgdin
谢谢,我试试
只看该作者
smthgdin
老会员
精华贴数 0
个人空间
0
技术积分 1319 (1285)
社区积分 1 (34698)
注册日期 2004-5-13
论坛徽章:2
#5
使用道具
发表于 2008-7-2 09:37
我的第一层select 多了no字段 要去掉。
__________________
www.kooboy.net
只看该作者
icedot
初级会员
精华贴数 0
个人空间
0
技术积分 10 (88495)
社区积分 0 (718033)
注册日期 2005-12-21
论坛徽章:0
#6
使用道具
发表于 2008-7-2 13:36
to smthgdin
您的这个写法,和我的效果差不多.
不过这个还不是我最终要得到的结果,开始是想要把问题简化,所以把重要部分抽出来举的一个例子,不过看来还是不能简化,因为简化了,就偏离方向了.
实际问题是这样的.
有一个新闻的发布系统,里面有文章:
1.湖北秭归县开通“七一”关怀热线(1)
2.湖北秭归县开通“七一”关怀热线(2)
3.台湾"高考"考场另类现象:清凉辣妹送补品
4.虎照真是一个农民制造的谎言? (1)
5.虎照真是一个农民制造的谎言? (2)
6.王岐山强调加强奥运保障工作的责任感和紧迫感
7.分析称时代华纳出售AOL Google或损失5亿美元
8.钢筋水泥下的货币战争 沈阳是房地产世外桃源
....
现在要读取最新文章,或是读某个分类的文章.
像:
1.湖北秭归县开通“七一”关怀热线(1)
2.湖北秭归县开通“七一”关怀热线(2)
这类文章,就是一篇新闻,只是进行了分页,所以对于这类新闻,只读取第一页,且显示标题为:湖北秭归县开通“七一”关怀热线
对于新闻,还需要把它发表日期,链接地址(同一篇新闻的每一页的地址不同),分类读取出来.
还请指教,我的语句要如何优化,谢谢.
只看该作者
smthgdin
老会员
精华贴数 0
个人空间
0
技术积分 1319 (1285)
社区积分 1 (34698)
注册日期 2004-5-13
论坛徽章:2
#7
使用道具
发表于 2008-7-2 14:47
哦
你加多个序号字段可能就好解决了。
dstinct后,页面显示标题。点击进去就可以看到1,2,3。。。。
__________________
www.kooboy.net
只看该作者
smxzgh
一般会员
精华贴数 0
个人空间
0
技术积分 304 (6394)
社区积分 0 (624195)
注册日期 2005-9-22
论坛徽章:1
#8
使用道具
发表于 2008-7-2 18:10
表结构设计问题
__________________
---------------------------------------------------
1 32 31 30 29 28 27 26 25
2 33 56 55 54 53 52 51 24
3 34 57 72 71 70 69 50 23
4 35 58 73 80 79 68 49 22
5 36 59 74 81 78 67 48 21
6 37 60 75 76 77 66 47 20
7 38 61 62 63 64 65 46 19
8 39 40 41 42 43 44 45 18
9 10 11 12 13 14 15 16 17
只看该作者
zikao419
初级会员
精华贴数 0
个人空间
0
技术积分 18 (59351)
社区积分 0 (1431817)
注册日期 2007-6-13
论坛徽章:0
#9
使用道具
发表于 2008-7-2 21:19
select distinct tt.no,tt.name from (select no,case when right(name,1)=')' then substring(name,1,len(name)-3) end as name from 表) as tt
这条语句好像不能满足“第一条”的条件吧
只看该作者
Ryan-liumin
晟夕
精华贴数 0
个人空间
0
技术积分 3366 (427)
社区积分 6231 (230)
注册日期 2008-5-4
论坛徽章:38
#10
使用道具
发表于 2008-7-5 09:48
呵呵 我的追求简单 还没到追求性能的那个阶段
__________________
用大海的容量,包容每个小小的心
只看该作者
投票
交易
悬赏
活动
相关内容
ITPUB论坛
≡ 数据库技术 ≡
> Oracle数据库管理
> Oracle开发
> Oracle Developer Suite
> Oracle入门与认证
> Oracle专题深入讨论
> Oracle新技术/11g
> Oracle电子文档
> Oracle Application Server套件
> IBM数据库产品
> MS SQL Server
> Sybase管理与开发
> MySQL及其它开源数据库
> 内存数据库
> 数据仓库与数据挖掘
> 移动及嵌入式数据库
≡ 企业信息化 ≡
> ERP产品与实践
> CRM产品与实践
> HR产品与实践
> 物流
> 供应链
> 供应链建模与仿真
> 物流设备与系统工程
> 企业管理咨询
> 管理协同与办公自动化
> IT服务管理
> 数据中心建设
> ERP二次开发
> Oracle ERP
> EBS相关文档
> PeopleSoft与JDE
> SAP R/3
> SAP Business One开发与快速实施
> SAP财务及CRM
> SAP后勤及HR
> mySAP ERP
> 系统开发及跨应用设置
> SAP相关文档
> 国外其它ERP产品
> 国内ERP产品
≡ 开发技术 ≡
> Java入门与认证版
> Java web开发及框架技术
> Java企业开发
> ASP.NET【已迁移到微软开发技术论坛】
> .Net企业开发与应用【已迁移到微软开发技术论坛】
> WEB程序开发
> WEB 2.0技术
> 动态语言
> 移动与游戏开发
≡ 系统设计与项目管理 ≡
> 系统分析与UML
> 系统分析与UML精华区
> 项目管理
> 项目过程
> 软件测试
> 算法讨论与研究
≡ IBM软件技术园地 ≡
> IBM数据库产品
> Lotus
> Tivoli
> Websphere
> Rational
> 与SOA相关的IBM产品与技术
> IBM软件技术精英协会
> 软件技术精英活动专版
≡ 操作系统与硬件 ≡
> AIX及IBM产品【已迁移到IXPUB】
> HP-UX及HP产品【已迁移到IXPUB】
> Solaris及SUN产品【已迁移到IXPUB】
> Linux及其应用 【已迁移到IXPUB】
> 其它UNIX系统【已迁移到IXPUB】
> windows系统及微软相关产品 【已迁移到IXPUB】
> 存储设备与容灾技术 【已迁移到IXPUB】
> 服务器 【已迁移到IXPUB】
≡ 行业纵向讨论区 ≡
> IT业界评论与展望
> 政府与教育事业
> 中国政府信息主管联盟
> 电信行业
> 金融行业
> 医卫行业
> 制造行业
> 电力行业
> 信息安全与审计
≡ 会员交流 ≡
> IT职业生涯
> 招聘求职商务信息
> 旅游,驴友
> 汽车世界
> 外语角
> 数码摄影
> 你的故事我的歌
> 音乐推荐区
> 电子图书与IT文档资料
> 软件交流
> 软件交流精华区
≡ ITPUB产品与服务 ≡
> ITPUB地面活动专版
> BLOG天地
> WIKI世界
> 授权用户区
> 站务管理
≡ 微软开发技术 ≡
> 开发工具和语言
> .NET Framework 相关
> Visual Basic/VB.net
> Visual C#
> Visual C++/vc.net
> Visual Studio
> .NET软件架构与模式
> .NET开发辅助工具及框架
> Web开发
> ASP.NET与AJAX
> Web相关技术讨论(IIS等)
> Silverlight 技术
> 微软企业级产品技术
> SQL Server
> windows server
> SharePoint
> Exchange Server
> Biztalk
> 嵌入式及移动开发
> Windows Embedded 嵌入式技术
> Windows 移动设备
> Office开发
> Microsoft office system
> Office Business Application
> 微软产品用户交流区
> .Net电子书籍&&书籍介绍
> .Net人才交流
技术积分榜
社区积分榜
徽章
电子杂志
会员
团队
统计
邮箱
游乐场
帮助
TOP
CopyRight 1999-2006 itpub.net All Right Reserved.
北京皓辰广域网络信息技术有限公司. 版权所有
E-mail:Webmaster@itpub.net
京ICP证:010037号
联系我们
法律顾问
控制面板首页
编辑个人资料
积分交易
公众用户组
好友列表
升级个人空间
基本概况
论坛排行
主题排行
发帖排行
积分排行
在线时间
管理团队
管理统计