在android 中,內置了sqlite資料庫,java web 中,用慣了Hibernate ,想找找android中是否也有類似的orm框架,後來在開源中國看到了orman,這是一個很不錯的框架。

這個可以幫我們快捷方便的實現資料庫的CURD操作。 下面以Users這個使用者類為例,和大家分享一下我的心得。

大家先在工程中導入orman的jar包。

這是我寫的users類

package xidian.wwf.entity;

import java.io.Serializable;

import org.orman.mapper.Model;
import org.orman.mapper.ModelQuery;
import org.orman.mapper.annotation.Column;
import org.orman.mapper.annotation.Entity;
import org.orman.mapper.annotation.PrimaryKey;
import org.orman.sql.C;

/**
* 使用者類
* @author WWF
* @date 2012-12-16 下午1:22:37
*/
@SuppressWarnings("serial")
@Entity(table="users")
public class Users extends Model<Users>implements Serializable{
@PrimaryKey//自增的話,@PrimaryKey(autoIncrement=true)
@Column(name="user_id",type="int")//映射的欄位名和類型,類型可以省略不寫
public int userId;
@Column(name = "user_name",type="text")
public String userName;
@Column(name="user_password",type="text")
public String userPassword;
@Column(name="login_time",type="text")
public String loginTime;

@Override
public void update() {
Model.execute(ModelQuery.update().from(Users.class)
.set(Users.class, "user_name", userName)
.set(Users.class, "user_password",userPassword)
.set(Users.class, "login_time", loginTime)
.where(C.eq("user_id", userId))
.getQuery());
}


}

因 為orman對於持久化的支援不咋符合我們的操作習慣,所以我個人比較喜歡重寫其update方法,就幾行代碼。 android中,欄位儘量少,存儲重要的資料。 所以這個工程量較少。 然後在應用啟動時,要註冊這個users類,在啟動的Application中註冊,

代碼如下

Database db = new SQLiteAndroid(this, AppConfig.DATABASE_PATH+AppConfig.DATABASE_FILENAME);
MappingSession.registerDatabase(db);
註冊實體類
MappingSession.registerEntity(Users.class);
MappingSession.registerEntity(Channel.class);
MappingSession.registerEntity(RSSItem.class);
MappingSession.registerEntity(ChannelGroup.class);
MappingSession.start();

然後在任何的Activity 中就可以使用了,

Users user = new Users();
插入
user.insert();
刪除
user.delete();
更新
user.update();
查詢
user = Model.fetchSingle(ModelQuery.select().from(Users.class).
where(C.eq("user_id", id)).getQuery(), Users.class);
查詢更多
List<Users> users = Model.fetchQuery(ModelQuery.select().from(Users.class).where(
C.like("user_name", "%2%")).getQuery(), Users.class);
創作者介紹
創作者 shadow 的頭像
shadow

資訊園

shadow 發表在 痞客邦 留言(0) 人氣()