ormlite是什么?
简单来说,就是我们定义一个实体类,利用这个框架,它可以帮我们吧这个实体映射到我们的数据库中,在Android中是SQLite,数据中的字段就是我们定义实体的成员变量。
官网地址为www.ormlite.com;我们需要在官网下两个依赖的jar包然后放在项目的libs目录中。
如何使用oralite
添加ormlite注解
这是我们新建的Message类,如图,当然还要设置get/set方法和一个无参构造函数
学过hibernate应该知道jpa,这里我们也可以使用标准的jpa来代替。
然后新建个类继承OrmLiteSqliteOpenHelper来生存数据库结构信息。
public class DatabaseHelper extends OrmLiteSqliteOpenHelper { private static final String DB_NAME = "mydata.db"; // 数据库名称
private static final int version = 2; // 数据库版本
//定义每一张表的成员变量,其中一个功能:关闭helper,所有DAO对象清理
private Dao<Message, Integer> messageDao; public Dao<Message, Integer> getMessageDao() {
if (messageDao==null){
try {
messageDao = getDao(Message.class);
} catch (SQLException e) {
e.printStackTrace();
}
}
return messageDao;
} public DatabaseHelper(Context context) {
super(context, DB_NAME, null, version);
} /*
* 1.此方法,不会自定执行,因为它不是回调函数
* 2.最好也不要自己调用,因为只应该执行1次
*/
@Override
public void onCreate(SQLiteDatabase arg0, ConnectionSource arg1) {
// TODO Auto-generated method stub } /*
* 此方法,不会自定执行,因为它不是回调函数
*/
@Override
public void onUpgrade(SQLiteDatabase arg0, ConnectionSource arg1, int arg2,
int arg3) {
// TODO Auto-generated method stub } @Override
public void close() {
super.close();
if (messageDao!=null){
messageDao = null;
}
} }
然后再我们android项目的mainactivity调用;
public class MainActivity extends Activity { private List<Message> messageList;//用于ORMLite 的演示
private DatabaseHelper db_helper; //其它activity或者service都无法获得 @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.weixin); } //UI呈现在眼前
@Override
protected void onResume(){
Log.i("ok", "onResume,界面出现了,app:"+app); 使用ORMLite
db_helper = new DatabaseHelper(this); Dao<Message, Integer> message_dao = db_helper.getMessageDao();
try {
messageList = message_dao.queryForAll(); //查询所有
//Log.i("ormlite", "记录条数:"+messageList3.size());
String t = "记录条数:"+messageList3.size();
Toast.makeText(this, t, Toast.LENGTH_LONG).show(); } catch (SQLException e) {
String t = "记出错:"+e.getMessage();
Toast.makeText(this, t, Toast.LENGTH_LONG).show();
} super.onResume();
} @Override
//UI完全消失在眼前,完全被另外一个进程覆盖
protected void onPause(){
Log.i("ok", "onPause,被抛弃");
db_helper.close();//??到底要不要?
super.onPause();
} }
这里附上ormlite的相关语句的使用方法:http://blog.****.net/industriously/article/details/50790624 (转载)