详解sql server的常见文件操作
Admin 2021-05-28 群英技术资讯 754 次浏览
这篇文章给大家分享的是有关sql server 文件操作的内容。小编觉得挺实用的,因此分享给大家作个参考,感兴趣的朋友就继续往下看吧。
在master数据库中,SQL Server提供系统扩展的存储过程,其中有一些存储过程的命名以xp_开头,用于处理操作系统的文件。
一,判断文件是否存在
存储过程sys.xp_fileexist 用于判断文件是否存在,参数是文件(file)的路径或目录的路径:
exec master.sys.xp_fileexist 'D:\test.txt'
该存储过程返回的结果集有一行数据,三个字段,如下图:
二,创建子目录
存储过程 sys.xp_create_subdir 用于创建子目录,参数是子目录的路径:
exec master.sys.xp_create_subdir 'D:\test'
执行存储过程,系统返回消息:Command(s) completed successfully,说明子目录创建成功。
三,查看子目录结构
存储过程sys.xp_dirtree 用于显示当前目录的子目录,该存储过程有三个参数:
exec master.sys.xp_dirtree 'D:\data'
该存储过程返回的字段有子目录名称和相对深度,返回的结果中并没有显示子目录的父子关系:
四,删除文件
存储过程 sys.xp_delete_file 用于删除文件,该存储过程有5个参数:
该存储过程并不可以删除所有的文件,系统限制它只能删除特定类型的文件。
declare @Date datetime = dateadd(day,-30,getdate()) exec master.sys.xp_delete_file 0,'D:\test\','bak',@Date,0
五,查看磁盘驱动的空闲空间
存储过程 sys.xp_fixeddrives用于查看磁盘驱动器剩余(free)的空间
exec sys.xp_fixeddrives
六,执行DOS命令操作文件
存储过程sys.xp_cmdshell 用于执行DOS命令,该功能对应SQL Server系统的xp_cmdshell高级选项,默认情况下,该选项是禁用的,执行该存储过程,系统会抛出错误消息:
SQL Server blocked access to procedure 'sys.xp_cmdshell' of component 'xp_cmdshell' because this component is turned off as part of the security configuration for this server. A system administrator can enable the use of 'xp_cmdshell' by using sp_configure. For more information about enabling 'xp_cmdshell', search for 'xp_cmdshell' in SQL Server Books Online.
因此,在执行该存储过程之前,必须启用xp_cmdshell选项,由于启用该选项有潜在的风险,建议用户在执行代码之后,禁用该选项。
1,启用/禁用xp_cmdshell选项
xp_cmdshell选项属于系统的高级选项,执行以下代码,允许用户修改高级选项:
-- To allow advanced options to be changed. exec sp_configure 'show advanced options', 1; go -- To update the currently configured value for advanced options. reconfigure; go
使用以下代码启用xp_cmdshell选项:
-- To enable the feature. exec sp_configure 'xp_cmdshell', 1; go -- To update the currently configured value for this feature. reconfigure; go
使用以下代码禁用xp_cmdshell选项:
-- To disable the feature. exec sp_configure 'xp_cmdshell', 0; go -- To update the currently configured value for this feature. reconfigure; go
2,常用的DOS命令
该存储过程使得用户可以通过TSQL命令执行DOS命令,
exec sys.xp_cmdshell 'command_string'
2.1 建立新文件或增加文件内容
格式:ECHO 文件内容>file_name
exec master.dbo.xp_cmdshell 'echo abc > D:\share\test.txt'
2.2 查看文件内容
格式:TYPE file_name
exec master.dbo.xp_cmdshell 'type D:\share\test.txt'
2.3 复制文件
格式: COPY file_name new_folder
exec master.dbo.xp_cmdshell 'copy D:\test\test.txt D:\share\'
2.4 显示目录
格式:DIR folder
exec master.dbo.xp_cmdshell 'dir D:\share\'
2.5 创建目录
格式:MD folder_name
exec master.dbo.xp_cmdshell 'md D:\share\test\'
2.6 删除目录
格式:RD folder
exec master.dbo.xp_cmdshell 'rd D:\share\test'
2.7 删除文件
格式:DEL file_name
exec master.dbo.xp_cmdshell 'del D:\share\test.txt'
2.8 重命名文件
格式:REN [盘符:][路径]〈旧文件名〉〈新文件名〉
exec master.dbo.xp_cmdshell 'ren D:\test\test.txt new.txt'
2.9 移动文件
格式:MOVE file_name new_folder
exec master.dbo.xp_cmdshell 'move D:\test\new.txt D:\share\'
2.10 切换目录
格式:CD[盘符:][路径名][子目录名]
总结
关于sql server的文件操作就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。想要了解更多SQL使用技巧,大家可以关注其他文章哦。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
SQL 内部链接INNER JOIN关键字选择两个表中具有匹配值的记录。_下文的讲解详细,步骤过程清晰,对大家进一步学习和理解相关知识有一定的帮助。有这方面学习需要的朋友就继续往下看吧!
学习SQL sever,查询语句是必须要掌握的,对此本文就给大家介绍一下关于sql server简单的查询语句,因为简单语句是基础,要想做复杂查询,先掌握简单查询语句很重要。
sqlserver中怎么样解决复杂查询的问题?对于这个问题,我们可以用cte解决复杂查询问题,下面小编就给大家分享一个使用cte解决复杂查询问题实例,在此代码中需要注意count函数,它统计了一个列,如果该列在某行的值为null,将不会统计该行,下面跟随小编来具体了解一下吧。
一些新手对于sql中identity自增的用法不是很了解,对此本文给大家介绍sql中identity自增的基本用法,重新设置identity的值、向identity字段插入数据等操作,有需要的朋友可以参考。
oracle截取字符串前几位可以通过substr函数来实现,substr函数语法是“substr(string,start,length)”,其参数string表示指定的要截取的字符串,参数start规定在字符串的何处开始 。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008