<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>

                合規國際互聯網加速 OSASE為企業客戶提供高速穩定SD-WAN國際加速解決方案。 廣告
                # 對象的 CRUD 操作 如果已知主鍵的值,那么可以使用這些方法進行 CRUD 操作 對 object 操作的四個方法 Read / Insert / Update / Delete ```go o := orm.NewOrm() user := new(User) user.Name = "slene" fmt.Println(o.Insert(user)) user.Name = "Your" fmt.Println(o.Update(user)) fmt.Println(o.Read(user)) fmt.Println(o.Delete(user)) ``` 如果需要通過條件查詢獲取對象,請參見[高級查詢](query.md#all) ## Read ```go o := orm.NewOrm() user := User{Id: 1} err := o.Read(&user) if err == orm.ErrNoRows { fmt.Println("查詢不到") } else if err == orm.ErrMissPK { fmt.Println("找不到主鍵") } else { fmt.Println(user.Id, user.Name) } ``` Read 默認通過查詢主鍵賦值,可以使用指定的字段進行查詢: ```go user := User{Name: "slene"} err = o.Read(&user, "Name") ... ``` 對象的其他字段值將會是對應類型的默認值 復雜的單個對象查詢參見 [One](query.md#one) ## ReadOrCreate 嘗試從數據庫讀取,不存在的話就創建一個 默認必須傳入一個參數作為條件字段,同時也支持多個參數多個條件字段 ```go o := orm.NewOrm() user := User{Name: "slene"} // 三個返回參數依次為:是否新創建的,對象 Id 值,錯誤 if created, id, err := o.ReadOrCreate(&user, "Name"); err == nil { if created { fmt.Println("New Insert an object. Id:", id) } else { fmt.Println("Get an object. Id:", id) } } ``` ## Insert 第一個返回值為自增健 Id 的值 ```go o := orm.NewOrm() var user User user.Name = "slene" user.IsActive = true id, err := o.Insert(&user) if err == nil { fmt.Println(id) } ``` 創建后會自動對 auto 的 field 賦值 ## InsertMulti 同時插入多個對象 類似sql語句 ``` insert into table (name, age) values("slene", 28),("astaxie", 30),("unknown", 20) ``` 第一個參數 bulk 為并列插入的數量,第二個為對象的slice 返回值為成功插入的數量 ```go users := []User{ {Name: "slene"}, {Name: "astaxie"}, {Name: "unknown"}, ... } successNums, err := o.InsertMulti(100, users) ``` bulk 為 1 時,將會順序插入 slice 中的數據 ## Update 第一個返回值為影響的行數 ```go o := orm.NewOrm() user := User{Id: 1} if o.Read(&user) == nil { user.Name = "MyName" if num, err := o.Update(&user); err == nil { fmt.Println(num) } } ``` Update 默認更新所有的字段,可以更新指定的字段: ```go // 只更新 Name o.Update(&user, "Name") // 指定多個字段 // o.Update(&user, "Field1", "Field2", ...) ... ``` 根據復雜條件更新字段值參見 [Update](query.md#update) ## Delete 第一個返回值為影響的行數 ```go o := orm.NewOrm() if num, err := o.Delete(&User{Id: 1}); err == nil { fmt.Println(num) } ``` Delete 操作會對反向關系進行操作,此例中 Post 擁有一個到 User 的外鍵。刪除 User 的時候。如果 on_delete 設置為默認的級聯操作,將刪除對應的 Post **Changed in 1.0.3** 刪除以后不會刪除 auto field 的值
                  <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>

                              哎呀哎呀视频在线观看