gpt4 book ai didi

database - 在 DB 中表示文件系统(在 SQL Server 2008 中使用 hierarchyid)

转载 作者:太空狗 更新时间:2023-10-30 01:44:57 25 4
gpt4 key购买 nike

我还没有找到这方面的任何具体示例,但我有兴趣使用 hierarchyid 数据类型来表示具有更新等的整个目录结构。这是为 hierarchyid 引用的一个常见用例,但我找不到任何构建此类示例的文章。

我只想表示整个目录结构,例如:

/dir1
/file1
/dir2
/dir2/dir3
/dir2/dir3/file2

** 我不是要将其与磁盘上的文件系统同步。它纯粹通过数据库表示。 **

最佳答案

下面是一个通过hierarchyid表示文件系统的例子:

/*
Setup:
- Create the table to hold the files
- nodeDepth is identifier of the depth for readability
- fullpath is the full path of the file or directory
- nodePath is the HierarchyID
- nodePath identifies the row within the tree
*/

DECLARE @t TABLE (
nodeID INT NOT NULL IDENTITY(1,1) PRIMARY KEY,
nodeDepth VARCHAR(10) NOT NULL,
fullPath VARCHAR(20) NOT NULL,
nodePath HIERARCHYID NOT NULL
)

加载数据:

/*
Load the nodePath value with the Parse command:
- The root node has a single /
- Every nodePath must begin and end with /
- /1/2/ the second item on level 2
*/

INSERT @t (fullPath, nodeDepth, nodePath) VALUES
('/','1',HIERARCHYID::Parse('/')),
('/dir1','1.1',HIERARCHYID::Parse('/1/1/')),
('/file1','1.2',HIERARCHYID::Parse('/1/2/')),
('/dir2','1.3',HIERARCHYID::Parse('/1/3/')),
('/dir2/dir3','1.3.1',HIERARCHYID::Parse('/1/3/1/')),
('/dir2/dir3/file2','1.3.1.1',HIERARCHYID::Parse('/1/3/1/1/'))

显示路径:

SELECT *
FROM @t

nodeID nodeDepth fullPath nodePath
----------- ---------- -------------------- --------
1 1 / 0x
2 1.1 /dir1 0x5AC0
3 1.2 /file1 0x5B40
4 1.3 /dir2 0x5BC0
5 1.3.1 /dir2/dir3 0x5BD6
6 1.3.1.1 /dir2/dir3/file2 0x5BD6B0

获取 file2 的祖先(向上一级):

SELECT * 
FROM @t
WHERE nodePath =
(SELECT nodePath.GetAncestor(1)
FROM @t
WHERE fullPath = '/dir2/dir3/file2')

nodeID nodeDepth fullPath nodePath
----------- ---------- -------------------- ---------
5 1.3.1 /dir2/dir3 0x5BD6

获取 dir2 的所有后代:

SELECT *
FROM @t
WHERE nodePath.IsDescendantOf(
(SELECT nodePath
FROM @t
WHERE fullPath = '/dir2')) = 1
AND fullPath <> '/dir2' /* Parent is considered its own descendant */

nodeID nodeDepth fullPath nodePath
----------- ---------- -------------------- --------
5 1.3.1 /dir2/dir3 0x5BD6
6 1.3.1.1 /dir2/dir3/file2 0x5BD6B0

获取根路径:

SELECT * 
FROM @t
WHERE nodePath = HIERARCHYID::GetRoot()

nodeID nodeDepth fullPath nodePath
----------- ---------- -------------------- --------
1 1 / 0x

获取file2的级别:

SELECT nodePath.GetLevel() AS level
FROM @t
WHERE fullPath = '/dir2/dir3/file2'

level
------
4

引用资料:

关于database - 在 DB 中表示文件系统(在 SQL Server 2008 中使用 hierarchyid),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7150794/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com