首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >带有"select top 1 @arastr = k“的异常Server查询

带有"select top 1 @arastr = k“的异常Server查询
EN

Stack Overflow用户
提问于 2015-07-10 00:20:33
回答 3查看 87关注 0票数 0
代码语言:javascript
复制
select  top 1 @arastr = k
from    #m
where   datalength(k) = (select max(datalength(k)) from #m)

这个查询是做什么的,select top 1 @arastr = k的意义是什么?这个查询是从一个已经工作了7-8年的存储过程中提取的,所以这个查询没有什么问题,但是我无法理解它做了什么。

(#m是在查询的早期部分创建的临时表。)

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2015-07-10 00:27:33

这是一种非常常见(但有点过时)的方法,可以将k的值输入(以前声明过的!)变量@arastr供以后使用。

函数DATALENGTH将测量例如VARCHAR的长度。

在任何情况下,前1位都只有一个结果行,“最长”k的值在@arastr中.

编辑:正如@jpw所指出的,如果有超过一个相同(最长)长度的k,这将是随机的。

在不知道#m是什么样子的情况下,'k‘中是什么样的数据,我不能再告诉你了。

票数 0
EN

Stack Overflow用户

发布于 2015-07-10 00:28:11

查询从临时表top中的列k中选择一个随机值(因为使用k时没有order by子句),并将其赋值给变量@arastr (据推测,变量@arastr以前已经声明过)。所选字符串将与表中最长的字符串(以字节为单位(由datalength函数度量)匹配)。

票数 3
EN

Stack Overflow用户

发布于 2015-07-10 02:34:00

如果它看起来像这样的话

代码语言:javascript
复制
SET @arastr = (SELECT TOP 1 k
                FROM    #m
                WHERE   DATALENGTH(k) = (SELECT MAX(DATALENGTH(k)) FROM #m))
票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31330500

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档