標籤:
GreenDAO:
會產生一個資料訪問,不用我們書寫訪問資料庫的代碼:
核心原理圖
產生代碼
就是用產生器產生一個對應的java類的產生工廠
public static void main(String[] args)
{
// id name age sex
// Schema s=new Schema(版本號碼, 程式碼封裝名);
Schema s = new Schema(1, "com.itheima.redbaby.dao");
// 描述 對象
Entity person = s.addEntity("Person");
person.addIdProperty().autoincrement().primaryKey();// id
person.addStringProperty("name");
person.addIntProperty("age");
person.addStringProperty("sex");
// 產生代碼
// new DaoGenerator().generateAll(s, 輸入路徑);
try {// .. 工作空間
new DaoGenerator().generateAll(s, "../greendao_redbaby/src/");
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
代碼產生在指定的路勁如下
測試代碼
@Test
public void testLoad() {
DaoSession sesion = getSession();
PersonDao person = sesion.getPersonDao();
Person p=person.load(1L);
Log.i("wzx", p.getName());
}
@Test
public void testLoadAll() {
DaoSession sesion = getSession();
PersonDao person = sesion.getPersonDao();
List<Person> list = person.loadAll();
for (Person p : list) {
Log.i("wzx", p.getName());
}
}
@Test
public void testInsert() {
DaoSession sesion = getSession();
// 擷取具體一個Dao PerpsonDao
PersonDao dao = sesion.getPersonDao();
Person p = new Person();
p.setAge(1);
p.setName("張三的歌");
p.setSex("man");
dao.insert(p);
}
public DaoSession getSession() {
// 描述資料 SHOPPING.db
// SqliteOpenHelper
// |--DevOpenHelper
SQLiteDatabase db = new DaoMaster.DevOpenHelper(mContext, "SHOPPING.db", null).getWritableDatabase();
DaoMaster dm = new DaoMaster(db);
// 擷取Dao的集合DaoSession PersonDao
DaoSession sesion = dm.newSession();
return sesion;
}
@Test
public void testDeleteByKey() {
DaoSession sesion = getSession();
PersonDao personDao = sesion.getPersonDao();
personDao.deleteByKey(1L);
}
@Test
public void testUpdate() {
DaoSession sesion = getSession();
PersonDao personDao = sesion.getPersonDao();
Person p=personDao.load(1L);
p.setAge(22);
p.setSex("woman");
personDao.update(p);
}
總結:
整體簡單了我們對資料庫的使用,使的我們不過過多的書寫SQL代碼;
只需要我們把資料庫的每一Row。 專話成為 JavaBean的欄位就可以了。
簡單粗暴;
SqLite 架構 GreenDAO