Android 中的ORM框架

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

這個能夠幫咱們快捷方便的實現數據庫的CURD操做。下面以Users這個用戶類爲例,和你們分享一下個人心得。android

你們先在工程中導入orman的jar包。web

這是我寫的users類sql

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中註冊,數據庫

代碼以下app

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

是否是很好用呀?省時省力……呵呵。。。ide

相關文章
相關標籤/搜索