0

我正在考虑将 LiteDb for C# 用作文档存储系统。

只要我知道文件的 ID,我就可以上传和下载 - 但我也希望可以选择搜索它。

LiteDb 文档提供了此命令,用于搜索存储在 Db 中特定“目录”中的所有文件;

 var files = db.FileStorage.Find("$/photos/2014/");

但是我不知道如何处理 files 变量。我无法将其转换为可用的字符串等。

例如,我想将其添加到列表视图中。

有没有人有使用 LiteDb 和文件搜索的经验?

4

2 回答 2

3

回答有点晚了,但它可能仍然有用。搜索文件的更好方法是访问“_files”集合,这将允许您搜索文件的元数据:

class _files
{
    public string Id { get; set; }
    public string filename { get; set; }
    public string mimeType { get; set; }
    public long length { get; set; }
    public int chunks{ get; set; }
    public DateTime uploadDate { get; set; }
    public object metadata { get; set; } //You could replace object with a custom class
}

然后,您可以使用“_files”类访问您的文件信息以进行搜索。在这种情况下,它将检索文件名中带有“somefile”的所有文件:

var files = new LiteDatabase("myDatabase.db")
    .GetCollection<_files>() //Accesses the _files collection where file info is stored
    .Find(file => file.Filename.Contains("somefile")); //Find files with "somefile" in the filename

然后,您可以遍历结果以访问文件的信息:

foreach(var searchResult in files)
{
    var fileInfo = $"Id: {searchResult.Id} | Filename: {searchResult.filename} | Length: {searchResult.length}";
    Console.WriteLine(fileInfo);
}

这将输出类似于:

Id: file1 | Filename: important.doc | Length: 73453
Id: file2 | Filename: less_important.doc | Length: 3476

此外,不要忘记为您经常搜索的属性创建索引。例如,在上面的示例中,我搜索了文件名。我可以为文件名属性创建一个索引,如下所示:

new LiteDatabase("myDatabase.db")
    .GetCollection<_files>()
    .EnsureIndex(files => files.filename); //Create an index for filename
于 2018-08-10T10:34:38.643 回答
0

我设法找出答案....共享它是否对其他人有用。

 listView1.Items.Clear();
        try
        {
    //"" is a blank search which will return all files. 
    //But could easily be a value from a textbox. It is loaded into the Array Files

            var files = db.FileStorage.Find("").ToArray();

    //go through each obj in the array and abstract FileName, ID and 
    //Created date, adding them each to a new array (mylist, mylist1 etc.)
foreach (object obj in files)
            {

                mylist = files.Select(I => Convert.ToString(I.Filename)).ToArray();
                mylist1 = files.Select(I => Convert.ToString(I.UploadDate)).ToArray();
                mylist2 = files.Select(I => Convert.ToString(I.Id)).ToArray();


            }

 //loop through the mylist arrays an create usable strings for each value.
            for (int i = 0; i < mylist.Length; i++)
            {
                name = mylist[i].ToString();
                datecreated = mylist1[i].ToString();
                id = mylist2[i].ToString();
 //add each value to a listview
                listView1.Items.Add(new ListViewItem(new string[] { name, datecreated,id }));

            }
于 2017-10-27T21:13:25.873 回答