1

sqlite データベースに大きなファイル (100 MB 以上) を保存したいと考えています。パフォーマンスが良くないことに気づきました。ファイルをローカル フォルダーに保存する必要がありますか、それともコードを書き直す必要がありますか?

       Shared Sub BlobToFile(ByVal Blob As Byte(), ByVal file As String)
        Dim MyData() As Byte = Blob
        Dim K As Long
        K = UBound(MyData)
        Dim fs As New FileStream _
         (file, FileMode.Create, _
          FileAccess.Write)
        fs.Write(MyData, 0, K)
        fs.Close()
        MyData = Nothing
        K = Nothing
    End Sub
    Shared Function FileToBlob(ByVal Filepath As String) As Byte()
        Dim fs As New FileStream _
     (Filepath, FileMode.Open, _
      FileAccess.Read)
        Dim MyData(fs.Length) As Byte
        fs.Read(MyData, 0, fs.Length)
        fs.Close()
        Return MyData
    End Function
'Then I Do this:
Dim x As New Sqliteparameter With {.Name ="@file", .value=Filetoblob("C:\Testfile.zip"), .DbType.Binary}
Dim y As New SqliteCommand With {.Commandtext = "INSERT INTO FILES(File) Values(@file);"}
y.Parameters.add(x)
y.Executenonquery()

どうも

4

1 に答える 1

3

通常、mssql サーバーなどでサポートされていない限り、データベース内に大きなファイルを格納しないことをお勧めします。ファイルの場所をデータベースに保存し、ファイルを何らかのファイルシステムに保存することをお勧めします。

于 2012-04-22T14:18:22.637 に答える