SQL小技巧之替换、统计表字段存储数据字节大小。

概要

最近在工作中要进行数据迁移,对有些大字段需要进行存储大小的统计,因此就总结了这篇文章


DATALENGTH函数

用于返回任何表达式的数据长度(以字节为单位)。这对于了解字段或变量在数据库中的实际存储大小非常有用,尤其是在处理可变长度的数据类型(如 VARCHAR, NVARCHAR, VARBINARY 等)时。

SELECT MAX(DATALENGTH(RESULT_DATA)) FROM KISC_INTELLECT_PRODUCER_LOG
SELECT MAX(DATALENGTH(ACCEPT_PARAM)) FROM KISC_INTELLECT_PRODUCER_LOG

SELECT MAX(DATALENGTH(RESULT_PARAM)) FROM KISC_INTELLECT_BIZ_LOG_DETAIL
SELECT MAX(DATALENGTH(RESULT)) FROM KISC_INTELLECT_BIZ_LOG_DETAIL
  • DATALENGTH 函数返回的是字段值的字节长度。如果你想要将字节长度转换为千字节(KB),你可以简单地将字节数除以 1024。

例如,如果你有一个字段,其 DATALENGTH 返回 3399806 字节,你可以使用以下公式来计算它占用的 KB 数:

KB = DATALENGTH(字段名) / 1024
KB = 3399806 / 10243324.23 KB

REPLACE、SUBSTRING函数配合使用

这两个函数搭配主要在更新字段数据的时候,进行字符串精确替换,但是这种也存在一定的缺陷,需要字符串比较固定的。

话不多说,直接上例子:

SELECT TOP 100 SUBSTRING(RESULT,22,6),SUBSTRING(RESULT,354,18) FROM KISC_INTELLECT_BIZ_LOG_DETAIL WHERE RULE_CODE = '30001'
UPDATE KISC_INTELLECT_BIZ_LOG_DETAIL SET RESULT = REPLACE(CAST(RESULT AS NVARCHAR(2000)),SUBSTRING(RESULT,354,18),'123456123456781234') WHERE RULE_CODE = '30001';

小结

今天就先总结到这里了,后续遇到更有意思的sql,继续写笔记。


  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xiaobangsky

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值