- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的SQLite有问题,当我调用DataBaseHelper(存储onCreate和onUpgrade方法)时它不起作用,即使DataBase的版本发生变化,并且我没有错误。
为了恢复我的应用程序,我的主要 Activity 调用 Singleton,它执行 DataBaseHelper。
我的主要 Activity :
public class irdesApplication extends Activity {
public static final String LOG_TAG="Droidnova";
private Context context = this;
CheckUpdate chUp;
ProgressBar bar;
TextView txtLoading;
Data d = new Data();
Singleton s;
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.page_loading);
bar = (ProgressBar) findViewById(R.id.ProgressBarLoad);
txtLoading = (TextView) findViewById(R.id.txtLoading);
new Thread(myThread).start();
bar.setProgress(0);
//Initialisation de la Base
s.getInstance(context);
// ---------- Constitution des logs ------------ //
int logParam =0;
Log.v(LOG_TAG, "logParam value" + logParam);
[...]
}
}
我的单例:
package com.irdes.db;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
public class Singleton {
private static Singleton instance;
private DataBaseHelper baseIrdes;
private SQLiteDatabase db;
private Data d = new Data();
private Singleton(Context context){
System.out.println("Construction du Singleton");
d.loadPercent = 10;
d.loadTxt = "Initialisation";
baseIrdes = new DataBaseHelper(context, d.dbName, null, d.dbVersion);
}
public static synchronized Singleton getInstance(Context context){
if (instance == null)
instance = new Singleton(context);
return instance;
}
public void setValue(SQLiteDatabase value){
db = value;
}
public SQLiteDatabase getValue(){
return db;
}
protected void open(){
//on ouvre la BDD en écriture
db = baseIrdes.getWritableDatabase();
}
protected void close(){
//on ferme l'accès à la BDD
db.close();
}
}
我的 DataBasHelper Activity :
public class DataBaseHelper extends SQLiteOpenHelper {
private Data d = new Data();
public DataBaseHelper(Context context, String name, CursorFactory factory, int version) {
super(context, name, factory, version);
System.out.println("Test");
// TODO Auto-generated constructor stub
}
@Override
public void onCreate(SQLiteDatabase db) {
d.updateDataBase = true;
//Activation prise en charge Foreign Keys
db.execSQL("PRAGMA foreign_keys = ON;");
[...]
db.execSQL("CREATE TABLE "+d.actualiteTable+" ("+d.colActualiteNum+ " INTEGER PRIMARY KEY , "+
d.colActualiteTitre+ " TEXT, "+d.colActualiteDate+" TEXT, "+d.colActualiteLien+" TEXT, "+d.colActualiteTypeActu+" INTEGER, " +
"FOREIGN KEY ("+d.colActualiteTypeActu+") REFERENCES "+d.typeActuTable+" ("+d.colTypeActuNum+"))");
[...]
System.out.println("Create table Complete");
InsertRows(db);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
[...]
db.execSQL("DROP TABLE IF EXISTS "+d.actualiteTable);
[...]
onCreate(db);
}
public void InsertRows (SQLiteDatabase bdd){
System.out.println("Chargement des données");
bdd = this.getWritableDatabase();
ContentValues cv=new ContentValues();
// --------- TypeActu -------- //
cv.put(d.colTypeActuNum, 1);
cv.put(d.coltypeActuLibelle, "Gen");
bdd.insert(d.typeActuTable, d.colTypeActuNum, cv);
[...]
bdd.close();
System.out.println("Données inserées");
}
还有数据类以便更好地理解:
public static final String dbName="irdesDB";
public static final int dbVersion=46;
public static final String actualiteTable="Actualite";
public static final String colActualiteNum="numActu";
public static final String colActualiteTitre="titre";
public static final String colActualiteDate="date";
public static final String colActualiteLien="lien";
public static final String colActualiteTypeActu="numTypeActu";
[...]
我也在这里的法国论坛上发帖,如果有帮助的话:http://www.developpez.net/forums/d1110144/java/general-java/java-mobiles/android/sqlite-onupgrade-ne-s-execute-plus/#post6141983
有什么问题吗?我不明白为什么 onCreate 和 onUpgrade 不执行。
最佳答案
这些方法仅在您调用 getWritableDatabase()
或 getReadableDatabase()
时调用。
在您的情况下,调用 baseIrdes.open()
方法。
同样的问题是地址 here .
关于java - 当我调用 onUpgrade 和 onCreate 时,它没有运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6817919/
我正在尝试通过向我的 android 应用程序中的 Sqlite 表添加一列来升级某个表。我在我的 DBHelper 的 onUpgrade 方法中添加了一个 alter table 语句。 这是我遇
我正在尝试调用 onUpgrade() 来更新我的包含几列的表格。然而,当我运行该应用程序时,我在插入语句中收到一条错误消息,指出该表中不存在列(我尝试在 onUpgrade() 中添加的列)。非常感
我对 onUpgrade 有点困惑。我正在开发我的应用程序,在开发过程中我确实更改了 DATABASE_VERSION 五次,所以现在是 6。 一切都很顺利,直到我从手机上完全卸载应用程序并重新构建它
我是 Android 和数据库的新手,我在 DatabaseIncomeOutcome.java 类中有这个方法: public DbHelper(Context context) {
我在 android 中的 SQLite 数据库中遇到问题。 在 SQLiteOpenHelper 类的 onCreate(SQLiteDatabase db) 方法中,我正在创建表。现在我在 Pla
我正在尝试更新我的 Android 应用程序中的数据库。当我更新版本号时,会调用 onUpgrade,但版本号不会增加,因此每次访问数据库时都会调用 onUpgrade。这是我的代码: private
我正在开发我的应用程序的第二个版本。我遇到了一个问题。 在我的应用程序中,数据库位于 Assets 文件夹中。现在我想从第二个版本的 Assets 文件夹更新我的数据库。 我尝试将代码升级为: //
我已经使用 onUpgrade() 添加了一个表,现在我刚刚意识到需要添加另一个表。我希望在不丢失任何以前的数据或表格的情况下执行此操作。 我尝试从 onUpgrade 中删除所有内容以添加新表,但它
我正在使用预填充的数据库。在 Mozilla 中使用 SQLite Manager,现在我有一个虚拟数据库,只是想测试 onUpgrade 方法,因此我更改了其中一列中的字符串,将其导出为新数据库,正
您可以在下面看到我的数据库助手类。我使用在 Assets 文件夹中导入的预填充 SQLite 数据库。每当我向现有数据库添加表时,如果我的应用程序已安装在手机上,则不会出现此类表错误。我想我的 onU
我在表格中添加了一列 (SUM)。我认为重写/重新创建表所需要做的就是为 DATABASE_VERSION 创建变量,但这不起作用。我的 onUpgrade() 方法中需要一些东西吗? 版本变量: p
您好,我目前正在开发一款语言词典应用。该数据库来 self 手动输入的 SQLite 数据库。该应用程序的特点是用户可以要求添加任何不在列表中的单词,因此每次更新应用程序时我都必须手动更新数据库。 问
情况是这样的。我正在升级我的数据库,添加一个列。升级似乎很顺利。我可以看到添加了新列,但问题是当我的应用程序从旧版本升级到带有新数据库的新版本时,我强制关闭了。访问新列时似乎发生强制关闭。但是,如果我
我的 onUpgrade 函数有一个小问题。代码如下: @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int n
我的 Android 应用程序中有一个只读数据库,我会定期更新该数据库。该应用始终在其 Assets 中携带最新版本的数据库。 我增加了传递给 SQLiteOpenHelper 子类的构造函数的版本号
在我的应用程序中,我有一个数据库,它是使用 DBHelper 类中的数据库查询创建的。我希望 onUpgrade 语句在安装 apk 时运行,因为用户可能会卸载并安装相同的应用程序。 在这种情况下,它
在我的 dbHelper 中: onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) 函数我将一张表保存到外部数据库。 所以我 附加
我正在尝试将我的数据库从版本 1 升级到版本 2。我正在分配 DATABASE_VERSION = 2(也分配了第一个版本)但从未调用过 onUpgrade .可能代码中有明显的错误,但我看不到它,因
在我的 Android 项目中,我有一个使用了一段时间的表。现在我想删除一列“image_byte”并添加一个新列“image_path”。我不能只是在使用应用程序时重命名该列,并且需要删除 imag
有人能解释一下如何在 SqliteDbOpenHelper 类中调用 onUpgrade 函数吗?我正在打开我的数据库,但它没有调用 onUpgrade,即使我已经更改了 DB_VERSION。 见以
我是一名优秀的程序员,十分优秀!