5.3 Model

2022-07-11 10:18 更新
Model 是 ActiveRecord 中最重要的組件之一,它充當(dāng) MVC 模式中的 Model 部分。以下是

Model 定義示例代碼:

public class User extends Model<User> {
public static final User dao = new User();
}
以上代碼中的 User 通過(guò)繼承 Model,便立即擁有的眾多方便的操作數(shù)據(jù)庫(kù)的方法。在 User 中聲明的 dao 靜態(tài)對(duì)象是為了方便查詢操作而定義的,該對(duì)象并不是必須的?;?ActiveRecord 的 Model 無(wú)需定義屬性,無(wú)需定義 getter、setter 方法,無(wú)需 XML 配置,無(wú)需 Annotation 配置, 極大降低了代碼量。
以下為 Model 的一些常見(jiàn)用法:

// 創(chuàng)建name屬性為James,age屬性為25的User對(duì)象并添加到數(shù)據(jù)庫(kù)
new User().set("name", "James").set("age", 25).save();
 
// 刪除id值為25的User User.dao.deleteById(25);
 
// 查詢id值為25的User將其name屬性改為James并更新到數(shù)據(jù)庫(kù)
User.dao.findByIdLoadColumns (25).set("name", "James").update();
 
// 查詢id值為25的user, 且僅僅取name與age兩個(gè)字段的值
User user = User.dao.findByIdLoadColumns (25, "name, age");
 
// 獲取user的name屬性
String userName = user.getStr("name");
 
// 獲取user的age屬性
Integer userAge = user.getInt("age");
 
// 查詢所有年齡大于18歲的user
List<User> users = User.dao.find("select * from user where age>18");
 
// 分頁(yè)查詢年齡大于18的user,當(dāng)前頁(yè)號(hào)為1,每頁(yè)10個(gè)user
Page<User> userPage = User.dao.paginate(1, 10, "select *", "from user where age > ?", 18);

特別注意:User 中定義的 public static final User dao 對(duì)象是全局共享的,只能用于數(shù)據(jù)庫(kù)查詢, 不能用于數(shù)據(jù)承載對(duì)象。數(shù)據(jù)承載需要使用 new User().set(…)來(lái)實(shí)現(xiàn)。

以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)