我的编程空间,编程开发者的网络收藏夹
学习永远不晚

SQL Server中怎么计算列是否占用空间

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

SQL Server中怎么计算列是否占用空间

SQL Server中怎么计算列是否占用空间,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

今天看网上有个问题:SQL Server计算列是否占用空间
其实这个问 题查一下MSDN或者BOL就可以知道结果了 。在创建计算列的时候有一个参数可以指定PERSISTED。使用这个参数可以指定数据库引擎将在表中物理存储计算值,并在计算列依赖的任何其他列发生更 新时对这些计算值进行更新。而且将计算列标记为 PERSISTED,便可对具有确定性、但不精确的计算列创建索引,提高性能。
如果不使用PERSISTED参数,那么计算列不会占用磁盘空间,但是查询计算列的时候要计算出值,这样性能会受影响(空间换性能)。
这里我们测试一下:
USE tempdb
GO
-- CreateTable
CREATE TABLE UDFEffect(ID INT,
FirstName VARCHAR(100),
LastName VARCHAR(100))
GO
-- Insert OneHundred Thousand Records
INSERT INTO UDFEffect(ID,FirstName,LastName)
SELECT TOP 100000 ROW_NUMBER() OVER (ORDER BY a.name) RowID,
'Bob',
CASE WHEN ROW_NUMBER() OVER (ORDER BY a.name)%2 = 1 THEN 'Smith'
ELSE 'Brown' END
FROM sys.all_objects a
CROSS JOIN sys.all_objects b
GO
-- Check thespace used by table
sp_spaceused 'UDFEffect'
GO

-- AddComputed Column
ALTER TABLE dbo.UDFEffect ADD
FullName AS (FirstName+' '+LastName)
GO
-- Check thespace used by table
sp_spaceused 'UDFEffect'
GO

可以看到表大小并没有改变,数据页没有增长。
-- AddComputed Column PERSISTED
ALTER TABLE dbo.UDFEffect ADD
FullName_P AS (FirstName+' '+LastName) PERSISTED
GO
-- Check thespace used by table
sp_spaceused 'UDFEffect'
GO

使用PERSISTED参数可以看到数据有增长。
-- Clean upDatabase
DROP TABLE UDFEffect
GO

看完上述内容,你们掌握SQL Server中怎么计算列是否占用空间的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

SQL Server中怎么计算列是否占用空间

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Java中怎么计算对象占用的空间

这篇文章给大家介绍Java中怎么计算对象占用的空间,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。对象头对象的头部至少有两个WORD,如果是数组的话,那么三个WORD,内容如下:对象的HashCode,锁信息等到对象类型
2023-06-17

C语言中怎么用浮点数计算三维空间的几何

在C语言中,可以使用浮点数来表示三维空间中的点、向量、线段等对象,并进行相关的几何运算,如计算两点之间的距离、向量的长度、点与线段的关系等。以下是一些常见的三维空间几何计算的示例代码:计算两点之间的距离:#include
C语言中怎么用浮点数计算三维空间的几何
2024-04-28

编程热搜

目录