将搜索结果排在前面,其余信息顺序排在后面,用SQL如何实现

静_心 2010-12-03 11:21:26
将搜索结果排在前面,其余信息顺序排在后面,用SQL如何实现
...全文
178 13 打赏 收藏 转发到动态 举报
写回复
用AI写文章
13 条回复
切换为时间正序
请发表友善的回复…
发表回复
静_心 2010-12-03
  • 打赏
  • 举报
回复
呕了。我设置的字段太小了。OK,搞定。谢谢各位!
静_心 2010-12-03
  • 打赏
  • 举报
回复
对 ORDER BY 子句中的项目数没有限制。但是,排序操作所需的中间工作表的行大小限制为 8,060 个字节。这限制了在 ORDER BY 子句中指定的列的总大小。

这句话应该怎么理解呢?
静_心 2010-12-03
  • 打赏
  • 举报
回复
Row_Number() OVER (ORDER BY子句有字数限制吗???
subxli 2010-12-03
  • 打赏
  • 举报
回复

create table book(
BookID int,
BookName varchar(50),
BookDesc varchar(50))

insert book
select 9,'net入门','親啟'
union all
select 6,'net入门','abcd'
union all
select 7,'xxx','net入门'
union all
select 8,'哈哈','美美'

--模糊查询,相关度排序

select * from Book where BookName like '%Net入门%' or BookDesc like '%Net入门%'
ORDER BY CASE WHEN BookName like '%Net入门%' THEN 1
WHEN BookDesc like '%Net入门%' THEN 2
END
静_心 2010-12-03
  • 打赏
  • 举报
回复
ORDER BY (CASE WHEN CHARINDEX('张三',unlook)>0 THEN 'a' else 'b' end)
很好,很强大,感谢!
jiangshun 2010-12-03
  • 打赏
  • 举报
回复
select * from tablename 
order by case when id=0 then 0 else 1 end

把ID=0的排前面,其余的后面

条件自己改,仅供参考
hzsasheng 2010-12-03
  • 打赏
  • 举报
回复

Select *,Case When title like '%CSDN%' Then 1 Else 0 End orderKey From Table
Order By orderKey Desc



这样就可以把表 Table 里面, title 包含 CSDN 的放在前面,其他放到后面~~
zzxap 2010-12-03
  • 打赏
  • 举报
回复
既然是查询,为什么要把无关数据显示在后面
whb147 2010-12-03
  • 打赏
  • 举报
回复
最简单的办法就是用2个div
第一个div就是专门用来显示查询结果的
第二个div就是常规显示数据的
默认情况下第一个不显示,或者为空
只有你点了查询按钮后才给第一个div赋值
边城的刀声 2010-12-03
  • 打赏
  • 举报
回复
边城的刀声 2010-12-03
  • 打赏
  • 举报
回复
查询所有ID大于30的记录

SELECT* FROM VW_FC_ALL_Chipin_Current ORDER BY (CASE when id>30 THEN 1 ELSE 2 END )

q107770540 2010-12-03
  • 打赏
  • 举报
回复
使用union
newdigitime 2010-12-03
  • 打赏
  • 举报
回复
如果你页面是重新加载,那太好办了.

如果不刷新,那就用ajax

62,042

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧