在android 中,內置了sqlite數據庫,java web 中,用慣了Hibernate ,想找找android中是否也有類似的orm框架,后來在開源中國看到了orman,這是一個很不錯的框架。
這個可以幫我們快捷方便的實現數據庫的CURD操作。下面以Users這個用戶類為例,和大家分享一下我的心得。
大家先在工程中導入orman的jar包。
這是我寫的users類
package xidian.wq.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;@Overridepublic 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);