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

文章目录

概要

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


DATALENGTH函数

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

sql 复制代码
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 数:

sql 复制代码
KB = DATALENGTH(字段名) / 1024
KB = 3399806 / 1024 ≈ 3324.23 KB

REPLACE、SUBSTRING函数配合使用

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

话不多说,直接上例子:

sql 复制代码
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,继续写笔记。


相关推荐
Absurd58715 分钟前
JavaScript中模块化在游戏引擎开发中的资源调度作用
jvm·数据库·python
2301_815279521 小时前
SQL如何利用聚合函数生成业务分析指标_KPI计算基础教程
jvm·数据库·python
qq_330037991 小时前
mysql如何排查Out of memory错误_mysql内存分配调优
jvm·数据库·python
weixin_458580122 小时前
如何在 Go 中直接将 AST 编译为可执行二进制文件?
jvm·数据库·python
Highcharts.js4 小时前
Highcharts Grid 中文站正式上线:表格数据处理的全新选择
前端·javascript·数据库·表格数据·highcharts·可视化图表·企业级图表
Elastic 中国社区官方博客7 小时前
Elasticsearch:使用 Agent Builder 的 A2A 实现 - 开发者的圣诞颂歌
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
2301_816660218 小时前
PHP怎么处理Eloquent Attribute Inference属性推断_Laravel从数据自动推导类型【操作】
jvm·数据库·python
qq_372154238 小时前
Go 中自定义类型与基础类型的显式转换规则详解
jvm·数据库·python
_下雨天.9 小时前
NoSQL之Redis配置与优化
数据库·redis·nosql
LiAo_1996_Y9 小时前
CSS如何实现文字渐变效果_通过background-clip实现艺术字
jvm·数据库·python