<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ThinkChat2.0新版上線,更智能更精彩,支持會話、畫圖、視頻、閱讀、搜索等,送10W Token,即刻開啟你的AI之旅 廣告
                [TOC] ## 內存數據庫 - 沒有打開任何磁盤文件,而是純粹在內存中創建一個新的數據庫。一旦關閉數據庫連接,數據庫就不復存在 - 在 3.5 以上版本支持在進程間共享內存 ### 基本的內存數據庫 go 示例 ``` db, err := gorm.Open(sqlite.Open(":memory:"), &gorm.Config{}) if err != nil { t.Error(err) } db.AutoMigrate(User{}) db.Create(&User{ UserName: "Bob", Password: "123", }) var user User db.First(&user) t.Logf("%#v",user) // main.User{ID:0x1, UserName:"Bob", Password:"123"} ``` #### 內存與文件數據庫的性能對比 <details> <summary>demo_test.go</summary> ``` func BenchmarkSqlite(b *testing.B) { b.Run("內存數據庫",BenchmarkMemory) b.Run("文件數據庫",BenchmarkFile) } func BenchmarkMemory(b *testing.B) { db, err := gorm.Open(sqlite.Open(":memory:"), &gorm.Config{}) if err != nil { b.Error(err) } db.AutoMigrate(User{}) db.Create(&User{ UserName: "Bob", Password: "123", }) for i := 0; i < b.N; i++ { var user User db.First(&user) } } func BenchmarkFile(b *testing.B) { db, err := gorm.Open(sqlite.Open("test2.db"), &gorm.Config{}) if err != nil { b.Error(err) } db.AutoMigrate(User{}) db.Create(&User{ UserName: "Bob", Password: "123", }) for i := 0; i < b.N; i++ { var user User db.First(&user) } } ``` </details> <br/> output ``` BenchmarkSqlite/內存數據庫-4 59682 21035 ns/op BenchmarkSqlite/文件數據庫-4 16357 85115 ns/op ``` ### 共享內存 1. 共享內存可以在不同進程簡共享 2. 共享內存有兩種寫作方式 方式一: memory:?cache=shared 方式二: file::memdb1?mode=memory&cache=shared ,此方式可以指定內存數據庫名字 <details> <summary>demo_test.go</summary> ``` func TestMemoryShare(t *testing.T) { //db, err := gorm.Open(sqlite.Open("file::memory:?cache=shared")) db, err := gorm.Open(sqlite.Open("file::memdb1?mode=memory&cache=shared")) if err != nil { t.Error(err) } db.AutoMigrate(User{}) db.Create(&User{ UserName: "Bob", Password: "123", }) //db1, err := gorm.Open(sqlite.Open("file::memory:?cache=shared")) db1, err := gorm.Open(sqlite.Open("file::memdb1?mode=memory&cache=shared")) if err != nil { t.Error(err) } var user User db1.First(&user) t.Logf("%#v",user) } ``` </details> <br/>
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看