1. 测试创建表变量对IO的影响 测试创建表变量前后,tempdb的空间大小,目前使用 sp_spaceused 得到大小,也可以使用视图 sys.dm_db_file_space_usage use tempdb go Set nocount on Exec sp_spaceused /* 插入数据之前 */ declare @tmp_orders table ( list_
1. 测试创建表变量对IO的影响
测试创建表变量前后,tempdb的空间大小,目前使用sp_spaceused得到大小,也可以使用视图sys.dm_db_file_space_usage
<span><span>use</span><span> tempdb </span><span>go</span> <span>Set</span> nocount <span>on</span> <span>Exec</span> sp_spaceused <span>/*</span><span>插入数据之前</span><span>*/</span> <span>declare</span> <span>@tmp_orders</span> <span>table</span> ( list_no <span>int</span>,id <span>int</span><span>) </span><span>insert</span> <span>into</span> <span>@tmp_orders</span><span>(list_no,id) </span><span>select</span> ROW_NUMBER() <span>over</span>( <span>order</span> <span>by</span><span> Id ) list_no,id </span><span>from</span><span> Test.dbo.Orders </span><span>Select</span> <span>top</span>(<span>1</span>) name,<span>object_id</span><span>,type,create_date </span><span>from</span><span> sys.objects </span><span>Where</span> type<span>=</span><span>'</span><span>U</span><span>'</span> <span>Order</span> <span>by</span> create_date <span>Desc</span> <span>Exec</span> sp_spaceused <span>/*</span><span>插入数据之后</span><span>*/</span> <span>Go</span> <span>Exec</span> sp_spaceused <span>/*</span><span>Go之后</span><span>*/</span></span>
执行结果如下:
可以看到:
1) 在表变量创建完毕,同时批处理语句没有结束时,临时库的空间增大了接近9M空间。创建表变量的语句结束后,空间释放
2)在临时库的对象表sys.objects中能够查询到刚刚创建的表变量对象
继续验证是否发生IO操作,使用视图sys.dm_io_virtual_file_stats
在创建表变量前后执行如下语句:
<span><span>select</span> <span>db_name</span>(database_id) database_name,<span>*</span> <span>from</span> sys.dm_io_virtual_file_stats(<span>db_id</span>(<span>'</span><span>tempdb</span><span>'</span>), <span>NULL</span>)</span>
测试结果如下:
1* 创建表变量前
2*创建表变量后
可以看到数据文件写入次数以及写入字节发生了明显的变化,比较写入字节数:
select (2921709568-2913058816)*1.0/1024/1024
大约为8.3M,与表变量的数据基本一致,可见创建表变量,确实是发生了IO操作
2. 测试创建表变量对内存的影响
考虑表变量是否占用内存的数据缓冲区,测试SQL如下:
<span><span>declare</span> <span>@tmp_orders</span> <span>table</span> ( list_no <span>int</span>,id <span>int</span><span>) </span><span>insert</span> <span>into</span> <span>@tmp_orders</span><span>(list_no,id) </span><span>select</span> ROW_NUMBER() <span>over</span>( <span>order</span> <span>by</span><span> Id ) list_no,id </span><span>from</span><span> Test.dbo.Orders </span><span>--</span><span>查询tempdb库中最后创建的对象 </span> <span>Select</span> <span>top</span>(<span>1</span>) name,<span>object_id</span>,type,create_date <span>from</span> sys.objects <span>Where</span> type<span>=</span><span>'</span><span>U</span><span>'</span> <span>Order</span> <span>by</span> create_date <span>Desc</span> <span>--</span><span>查询内存中缓存页数 </span> <span>SELECT</span> <span>count</span>(<span>*</span>)<span>AS</span><span> cached_pages_count ,name ,index_id </span><span>FROM</span> sys.dm_os_buffer_descriptors <span>AS</span><span> bd </span><span>INNER</span> <span>JOIN</span><span> ( </span><span>SELECT</span> <span>object_name</span>(<span>object_id</span>) <span>AS</span><span> name ,index_id ,allocation_unit_id </span><span>FROM</span> sys.allocation_units <span>AS</span><span> au </span><span>INNER</span> <span>JOIN</span> sys.partitions <span>AS</span><span> p </span><span>ON</span> au.container_id <span>=</span><span> p.hobt_id </span><span>AND</span> (au.type <span>=</span> <span>1</span> <span>OR</span> au.type <span>=</span> <span>3</span><span>) </span><span>UNION</span> <span>ALL</span> <span>SELECT</span> <span>object_name</span>(<span>object_id</span>) <span>AS</span><span> name ,index_id, allocation_unit_id </span><span>FROM</span> sys.allocation_units <span>AS</span><span> au </span><span>INNER</span> <span>JOIN</span> sys.partitions <span>AS</span><span> p </span><span>ON</span> au.container_id <span>=</span><span> p.partition_id </span><span>AND</span> au.type <span>=</span> <span>2</span><span> ) </span><span>AS</span><span> obj </span><span>ON</span> bd.allocation_unit_id <span>=</span><span> obj.allocation_unit_id </span><span>WHERE</span> database_id <span>=</span> <span>db_id</span><span>() </span><span>GROUP</span> <span>BY</span><span> name, index_id </span><span>ORDER</span> <span>BY</span> cached_pages_count <span>DESC</span></span>
测试结果如下:
可以看到表变量创建后,数据页面也会缓存在Buffer Pool中。但所在的批处理语句结束后,占用空间会被释放。
3. 结论
SQL Server在批处理中创建的表变量会产生IO操作,占用tempdb的空间,以及内存bufferPool的空间。在所在批处理结束后,占用会被清除
参考文章:
http://www.cnblogs.com/CareySon/archive/2012/06/11/2544835.html
http://www.cnblogs.com/wghao/archive/2011/11/02/2227219.html
如有不对的地方,欢迎拍砖,谢谢!O(∩_∩)O

对于 SQL Server 数据库中已存在同名对象,需要采取以下步骤:确认对象类型(表、视图、存储过程)。如果对象为空,可使用 IF NOT EXISTS 跳过创建。如果对象有数据,使用不同名称或修改结构。使用 DROP 删除现有对象(谨慎操作,建议备份)。检查架构更改,确保没有引用删除或重命名的对象。

当 SQL Server 服务无法启动时,可采取以下步骤解决:检查错误日志以确定根本原因。确保服务帐户具有启动服务的权限。检查依赖项服务是否正在运行。禁用防病毒软件。修复 SQL Server 安装。如果修复不起作用,重新安装 SQL Server。

要查看 SQL Server 端口号:打开 SSMS,连接到服务器。在对象资源管理器中找到服务器名称,右键单击它,然后选择“属性”。在“连接”选项卡中,查看“TCP 端口”字段。

SQL Server 数据库文件通常存储在以下默认位置:Windows: C:\Program Files\Microsoft SQL Server\MSSQL\DATALinux: /var/opt/mssql/data可通过修改数据库文件路径设置来自定义数据库文件位置。

问题发现这次使用的是SqlServer数据库,之前并没有使用过,但是问题不大,我按照需求文档的步骤连接好SqlServer之后,启动SpringBoot项目,发现了一个报错,如下:刚开始我以为是SqlServer连接问题呢,于是便去查看数据库,发现数据库一切正常,我首先第一时间问了我的同事,他们是否有这样的问题,发现他们并没有,于是我便开始了我最拿手的环节,面向百度编程。开始解决具体报错信息是这样,于是我便开始了百度报错:ERRORc.a.d.p.DruidDataSource$CreateCo

SQL Server 英文安装可通过以下步骤更改为中文:下载相应语言包;停止 SQL Server 服务;安装语言包;更改实例语言;更改用户界面语言;重启应用程序。

有网友反馈,在win11上无法安装sqlserver这款软件,不知道是怎么回事,根据目前的测试来看,win11存在硬盘问题,部分接口硬盘无法安装这款软件。win11为啥不能安装sqlserver:答:win11不能安装sqlserver是硬盘的问题。1、据了解,win11存在对于硬盘的检测bug。2、这导致sqlserver无法在“三星m.2接口”硬盘上安装。3、因此,如果我们要安装的话,需要准备一块其他硬盘。4、然后将该硬盘安装到电脑里,如果没有额外插槽的话就要换掉之前的硬盘。5、安装完成后,

可以通过以下步骤查询 SQL Server 数据库日志:1. 打开 SQL Server Management Studio,连接到数据库服务器;2. 展开“管理”节点,导航到“SQL Server 日志”;3. 选择要查询的日志文件,右键单击并选择“查看日志文件”;4. 浏览日志记录。其他查询日志方法:使用 Transact-SQL 查询、PowerShell Cmdlet。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

SublimeText3 Linux新版
SublimeText3 Linux最新版

SublimeText3汉化版
中文版,非常好用

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)