首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何计算SQL 11数据库表中一行的哈希值?

如何计算SQL 11数据库表中一行的哈希值?
EN

Stack Overflow用户
提问于 2011-02-23 20:48:21
回答 2查看 2.2K关注 0票数 2

我的应用程序一直在轮询数据库。为了达到优化的目的,我希望应用程序只在表被修改后才查询数据库。因此,我想计算整个表的哈希,并将其与上次保存的表哈希进行比较。(我计划先计算每一行的哈希,然后再计算它们的散列,即HASHes的哈希)

我发现Server有校验和() sql实用程序函数,它计算一行的散列/校验和。

是否有类似的实用程序/查询来查找11数据库中的行的散列?

FYI,数据库表不具有任何带有预先计算的散列/校验和的颜色。

EN

回答 2

Stack Overflow用户

发布于 2011-03-01 11:32:42

找到答案了。我们可以使用以下查询计算表的特定列上的散列:

代码语言:javascript
复制
-- SELECT HASH(coulum_name, hash_algorithm) 
-- For example:
SELECT HASH(coulmn, 'md5') 
FROM MyTable
票数 1
EN

Stack Overflow用户

发布于 2013-08-21 13:39:14

这将对表的所有数据创建一个散列,以检测任何列中的更改:

代码语言:javascript
复制
CREATE VARIABLE @tabledata LONG VARCHAR;
UNLOAD TABLE MyTable INTO VARIABLE @tabledata ORDER ON QUOTES OFF COMPRESSED;
SET @tabledata = Hash(@tabledata);
IF (@tabledata <> '40407ede9683bcfb46bc25151139f62c') THEN
    SELECT @tabledata AS hash;
    SELECT * FROM MyTable;
ENDIF;
DROP VARIABLE @tabledata;

当然,这是昂贵的,不应该使用,如果数据是数百兆字节。但是,如果唯一的其他方法是比较所有数据的任何更改,这将是更快的,并产生负载和内存消耗仅在db服务器。

如果只需要对少数列进行更改检测,则可以使用UNLOAD SELECT col FROM table INTO ...

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5096905

复制
相关文章

相似问题

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