【问题标题】:shift / rotate the output of a sql server query for advertising purposes转移/旋转用于广告目的的 sql server 查询的输出
【发布时间】:2011-10-10 03:24:31
【问题描述】:

我正在尝试创建一个查询,该查询将改变我网站上每个用户每次执行的结果。目标是使用 SQL Server 2008 数据库技术实现这一目标。

例如,如果我有一个包含三行数据的表:

我正在尝试找到一种方法,通过名称升序然后移动/旋转结果来选择此数据顺序。

ID  Name 
1   Apple 
2   Orange 
3   Banana

用户 1 加载页面并看到

Apple
Banana
Orange

用户 1 重新加载同一页面,然后看到

Banana
Orange
Apple

用户 1 重新加载同一页面,然后看到

Orange
Apple
Banana

用户 2 等具有完全相同的体验,以相同的顺序旋转/移动结果。

我可以创建和存储任何必要的值,例如名字或姓氏或 ID。

是否有一个简单优雅的解决方案(查询、存储过程、函数等)可以在 SQL Server 级别完成这项任务?

原因是让所有颜色都有机会显示在列表顶部,而不是按字母顺序从 A 到 Z。

【问题讨论】:

  • 行数是固定的吗?基本排序是按字母顺序排列还是随机排列还是按 id 排列?
  • 没有基于类别的数据更改,至少一个,也许上限是 20 行,但通常少很多,可能是三到五个结果。

标签: sql sql-server-2008 rotation shift


【解决方案1】:

如果 SQL Server 具有序列和 nextval() 函数(如 PostgreSQL 或 Oracle),那么它可能就这么简单 - 假设您的基本排序在 id 上,从 1 开始,没有漏洞:

SELECT id, name
  FROM mytbl
 ORDER BY CASE WHEN id > @nextval%number_of_rows THEN 0 ELSE 1 END, rn

请参阅此处了解解决方法:Oracle sequence but then in MS SQL Server

使用来自问题的新输入进行编辑

它可能看起来像这样:

DECLARE @nextval int;

WITH x AS
(
SELECT id
      ,name
      ,ROW_NUMBER() OVER(ORDER BY name) AS rn
      ,COUNT(*) OVER() AS ct
  FROM mytbl 
)
SELECT id
      ,name
  FROM x
 ORDER BY CASE WHEN rn > @nextval%ct THEN 0 ELSE 1 END, rn
  • 按字母顺序排序。
  • 动态行数。
  • 语法现已测试
  • 您只需要增加@nextval 的方法。上面的链接可能会有所帮助。

为了弄清楚我的语法,我在data.stackexchange.com上写了一个演示
你可以去那里看看!

如果 SQL Server 有 LIMIT 和 OFFSET 之类的东西,这会更简单。 TOP 无法完成这项工作。见:Equivalent of LIMIT and OFFSET for SQL Server?

【讨论】:

  • 感谢您的想法。最终我的例子被简化了。理想情况下,我会按字母顺序对名称进行排序并旋转/移动。我将更新原始问题以表明这一点。
  • 对我有用,我实际上可以为每个用户存储和递增一个数字,以保持我在第一次执行时初始化为 0 的位置。非常感谢!
【解决方案2】:

我不知道 SQL 服务器查询的 shift 或 rotate 输出,但我正在尝试和你一样,我使用 NEWID() 来随机排序我的输出。

select name,company,etc from tblCompany order by NEWID() desc

【讨论】:

  • 有趣的想法,但当时我需要专门轮播广告,实际上我需要针对每个用户执行此操作,以确保显示时间相等。感谢您在我的第 50 天生日时提出这个问题!干杯!
猜你喜欢
  • 1970-01-01
  • 2011-09-16
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-05-24
  • 1970-01-01
相关资源
最近更新 更多