http://www.bkjia.com/Androidjc/755545.html 转自
OrmLite可以帮助我们将会数据库操作,不用自己去写SQL语句,而且设置它跟使用Sqlite一样的方式,它是一种关系型数据,我比较喜欢的就是它能够帮助我判断数据表项是更新还是创建等操作,不需要自己去写大量的SQL语句去判断,下面介绍一下它的使用文档以及一些基本的注意点:
官方网址:http://ormlite.com/
JavaDOC地址:http://ormlite.com/javadoc/ormlite-android/
开发文档地址:http://ormlite.com/javadoc/ormlite-core/doc-files/ormlite.html
首先创建一个Model,作为一个数据表,在Android中我使用的是实现Parcelable,代码如下:
package com.jwzhangjie.capricorntv.bean; import com.j256.ormlite.field.DatabaseField; import com.j256.ormlite.table.DatabaseTable; import android.os.Parcel; import android.os.Parcelable; /** * * @author zj 包含视频的参数 视频的名字 "channel_id":9, "channel_name":"湖南卫视", * "icon_url":"http://tv.togic.com:8080/ShowTimeService/images/182.png", * "province":"湖南", "mode":"SD", "url": * "http://live.gslb.letv.com/gslb?stream_id=hunan&tag=live&ext=m3u8&sign=live_tv&platid=10&splatid=1012&temporarykey=db7c39a0ee39ab2d4d2e781d5" * , * "second_url":["http://live-cdn.kksmg.com/channels/tvie/test/flv:500k" * , * "http://live.gslb.letv.com/gslb?stream_id=hunanHD_1800&tag=live&ext=m3u8&sign=live_tv&platid=10&splatid=1012&temporarykey=db7c39a0ee39ab2d4d2e781d5" * , * "http://pplive.shntv.cn/live/5/30/e9301e073cf94732a380b765c8b9573d.m3u8?type=ipad" * ,"rtsp://rlive.tv189.cn/live/112"], "types":"2|0" */ public class LiveItemBean implements Parcelable { @Override public int describeContents() { return 0; } public LiveItemBean() { } private LiveItemBean(Parcel source) { readFromParcel(source); } @DatabaseField(id = true) private int channel_id; @DatabaseField private String channel_name; @DatabaseField private String icon_url; @DatabaseField private String province; @DatabaseField private String mode; @DatabaseField private String url; @DatabaseField private String second_urls; private String[] second_url; @DatabaseField private String types; private void readFromParcel(Parcel source) { channel_name = source.readString(); icon_url = source.readString(); province = source.readString(); mode = source.readString(); url = source.readString(); second_urls = source.readString(); second_url = (String[]) source.readArray(LiveItemBean.class .getClassLoader()); types = source.readString(); } @Override public void writeToParcel(Parcel dest, int flags) { dest.writeInt(channel_id); dest.writeString(channel_name); dest.writeString(icon_url); dest.writeString(province); dest.writeString(mode); dest.writeString(url); dest.writeString(second_urls); dest.writeArray(second_url); dest.writeString(types); } public static Creator CREATOR = new Creator() { @Override public LiveItemBean createFromParcel(Parcel source) { return new LiveItemBean(source); } @Override public LiveItemBean[] newArray(int size) { return new LiveItemBean[size]; } }; public int getChannel_id() { return channel_id; } public void setChannel_id(int channel_id) { this.channel_id = channel_id; } public String getChannel_name() { return channel_name; } public void setChannel_name(String channel_name) { this.channel_name = channel_name; } public String getIcon_url() { return icon_url; } public void setIcon_url(String icon_url) { this.icon_url = icon_url; } public String getProvince() { return province; } public void setProvince(String province) { this.province = province; } public String getMode() { return mode; } public void setMode(String mode) { this.mode = mode; } public String getUrl() { return url; } public void setUrl(String url) { this.url = url; } public String getSecond_urls() { return second_urls; } public void setSecond_urls(String second_urls) { this.second_urls = second_urls; } public String[] getSecond_url() { return second_url; } public void setSecond_url(String[] second_url) { this.second_url = second_url; StringBuffer buffer = new StringBuffer(); int count = second_url.length; for (int i = 0; i < count; i++) { buffer.append(second_url[i]); if (i != count-1) { buffer.append(";"); } } second_urls = buffer.toString(); } public String getTypes() { return types; } public void setTypes(String types) { this.types = types; } }
我们分析上面的代码同时介绍一下与之相关的配置:
1、是类名,这里我使用的数据表的名字是默认类的小写,当然你还可以指定表名字,使用@DatabaseTable(tableName = "liveitembeans"),
2、主键,在上面的代码中有一行@DatabaseField(id = true)被注解对象就是主键,当然我们有时候使用的一个自增长的id,我们可以设置为@DatabaseField(generatedId = true)来实现,当然还有很多其他的注解配置我这里就不一一说明了,自己可以到官网可以查看找到自己需要的。
package com.jwzhangjie.capricorntv.db; import android.content.Context; import android.database.sqlite.SQLiteDatabase; import com.j256.ormlite.android.apptools.OrmLiteSqliteOpenHelper; import com.j256.ormlite.support.ConnectionSource; import com.j256.ormlite.table.TableUtils; import com.jwzhangjie.capricorntv.bean.LiveItemBean; public class DBHelper extends OrmLiteSqliteOpenHelper { private static final String DATABASE_NAME = "jwzhangjie.db"; private static final int DATABASE_VERSION = 1; public DBHelper(Context context){ super(context, DATABASE_NAME, null, DATABASE_VERSION); } @Override public void onCreate(SQLiteDatabase sqLiteDatabase, ConnectionSource connectionSource) { try { TableUtils.createTable(connectionSource, LiveItemBean.class); } catch (Exception e) { e.printStackTrace(); } } @Override public void onUpgrade(SQLiteDatabase sqLiteDatabase, ConnectionSource connectionSource, int oldVer, int newVer) { try { TableUtils.dropTable(connectionSource, LiveItemBean.class, true); onCreate(sqLiteDatabase, connectionSource); } catch (Exception e) { e.printStackTrace(); } } }
上面使用TableUtils来创建和删除表,还有其他的功能例如清空表内容等
接下来就是创建一个操作数据库的工具DAO
package com.jwzhangjie.capricorntv.uitls; import java.sql.SQLException; import java.util.ArrayList; import java.util.List; import android.content.Context; import com.j256.ormlite.dao.Dao; import com.jwzhangjie.capricorntv.bean.LiveItemBean; import com.jwzhangjie.capricorntv.db.DBHelper; public class DBUtils { public static Dao liveDao = null; public DBUtils(Context context) { if (liveDao == null) { DBHelper dbHelper = new DBHelper(context); try { liveDao = dbHelper.getDao(LiveItemBean.class); } catch (SQLException e) { e.printStackTrace(); } } } /** * 插入直播数据,如果数据存在则进行更新 * * @param liveItemBean */ public void LiveCreate(LiveItemBean liveItemBean) { try { liveDao.createOrUpdate(liveItemBean); } catch (SQLException e) { e.printStackTrace(); } } /** * 连续进行插入,如果存在则更新 */ public void LiveCreates(List lists) { try { for (LiveItemBean liveItemBean : lists) { liveDao.createOrUpdate(liveItemBean); } } catch (Exception e) { e.printStackTrace(); } } /** * 查询所有的直播元素 * @return */ public List getLiveItemBeans(){ List listsBeans = new ArrayList(); try { listsBeans = liveDao.queryForAll(); } catch (SQLException e) { e.printStackTrace(); } return listsBeans; } }
上面实现了创建和查询,在上面的有一个连续插入多个数据,还可以使用OrmLite提供的批处理任务方法如下:
/** * 连续进行插入,如果存在则更新 */ public void LiveCreates(final List lists) { try { liveDao.callBatchTasks(new Callable() { @Override public Void call() throws Exception { for (LiveItemBean liveItemBean : lists) { liveDao.createOrUpdate(liveItemBean); } return null; } }); } catch (Exception e) { e.printStackTrace(); } }
查询除了用已有的接口,我们还可以使用sql语句来实现,比如:
// find out how many orders account-id #10 has GenericRawResults rawResults = orderDao.queryRaw( "select count(*) from orders where account_id = 10"); // there should be 1 result List results = rawResults.getResults(); // the results array should have 1 value String[] resultArray = results.get(0); // this should print the number of orders that have this account-id System.out.println("Account-id 10 has " + resultArray[0] + " orders");
当我们应用退出时候,我们需要释放之前对象
OpenHelperManager.releaseHelper(); dbHelper = null;