SQL Server 中执行Shell脚本计算本地文件的内容大小

  SQL Server 数据库中除了能执行基本的SQL语句外,也可以执行Shell脚本。默认安装后,SQL中的Shell脚本的功能是关闭的,需要手动打开,

执行以下脚本即可打开该功能。

-- 允许配置高级选项(1:允许  0:禁止)
EXEC sp_configure 'show advanced options', 1
GO
-- 重新配置
RECONFIGURE
GO

-- 启用xp_cmdshell(1:启用 0:禁用) EXEC sp_configure 'xp_cmdshell', 0 GO
--重新配置 RECONFIGURE GO

 

在本地系统C盘根目录下常见一个测试文件,123.txt,内容为:你好,我好,大家好。

在SQL Server查询分析器中执行以下脚本:

--判断临时表是否已经存在
IF OBJECT_ID('tempdb..#TempTable') IS NOT NULL
BEGIN
    DROP TABLE #TempTable;--删除临时表
END

--创建临时表
CREATE TABLE #TempTable
(
    Size varchar(8000)
)

--执行shell脚本并将结果插入临时表中
INSERT INTO #TempTable exec xp_cmdshell 'for /f %i in ("C:\123.txt") do  @echo %~zi'

--查询结果
SELECT * FROM #TempTable 

结果如下:

文件大小为20字节。

 

关于Windows Shell 脚本的技术请参考专业的技术资料。

 

转载于:https://www.cnblogs.com/SavionZhang/p/5529921.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值