android 使用sqlitedatabase,使用的时候需要在数据库中加入数据(只执行一次),我想问的是,这个加数据的

放在哪,才使这个动作从安装到卸载只执行一次呢... 放在哪,才使这个动作从安装到卸载只执行一次呢 展开
 我来答
shen6983846
2013-08-05 · TA获得超过383个赞
知道小有建树答主
回答量:229
采纳率:0%
帮助的人:257万
展开全部
加个判断你放在哪里都可以。
插入时候先写个查询数据库方法,判断是否返回为空。。。。
if(null){
插入。。。
}else{
不插入。。。
}

或者。你程序是否有向导页。。那玩意一般都是只第一次运行时候会执行一次。。可以在执行向导页时候插入。或者你可以借鉴向导页的实现方法,来实现你的功能。第一次运行SharedPreferences 赋值为true ,之后判断为true就不执行插入。
追问
怎么判断数据库是否为空的,可以通过查询这个方法来写这个方法把
追答
是滴。。写查询语句,写一个List>返回类型的方法,查询这个表 selete * from table 。判断这个方法的返回值是否为空。

private SQLiteDatabase mDbRead;
private MyDatabase myDatabase; // 继承SQLiteOpenHelper的数据库
public List> queryAllDatas(){
List> dataList;
try {
dataList = new ArrayList>();
mDbRead = myDatabase.getReadableDatabase();
// 查询
mCursor = mDbRead.rawQuery("select * from " + “表名”, null);
if (mCursor != null) {
//如果查询不到数据,while是不会执行的
while (mCursor.moveToNext()) {
Map map = new HashMap();
// 列出所有字段
map.put(“字段名”, mCursor.getInt(mCursor.getColumnIndex(“字段名”)));
map.put(“字段名”,mCursor.getString(mCursor.getColumnIndex(“字段名”)));
dataList.add(map);
}
return dataList;
}
return null;
} catch (Exception e) {
return null;
}finally{
if (mCursor != null)
mCursor.close();
if (mDbRead != null)
mDbRead.close();
}
}

用时候if(queryAllDatas() == null){
调用插入方法。。。
}
kq和你一起
2013-08-05 · 超过18用户采纳过TA的回答
知道答主
回答量:78
采纳率:0%
帮助的人:40.4万
展开全部
你为什么不设置一个按钮 用于插入数据啊 这样你想插入的时候就执行了 不想插入就不要点击执行啊
追问
那么简单就好咯
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式