- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在创建一个引用另一个数据库中的键的数据库。本质上,我有一个数据导入,我想将这些数据与将要更改的数据分开,但如果可能的话,我想通过 FOREIGN KEY
引用其他键。据我所知,我需要先附加数据库才能实现。到目前为止,这是相关代码:
public class LogDatabaseHelper extends SQLiteOpenHelper {
private static final String DATABASE_NAME = "log.db";
private static final int DATABASE_VERSION = 1;
private String namesDb;
public LogDatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
namesDb=getNamesDbPath();
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL("ATTACH DATABASE ? AS names",new String[]{namesDb});
StringBuilder query=new StringBuilder();
query.append("CREATE TABLE log (");
}
}
但是,这似乎不起作用,因为我收到以下错误:
11-21 17:35:58.176: E/SQLiteLog(9984): (1) statement aborts at 5: [ATTACH DATABASE ? AS names] cannot ATTACH database within transaction
11-21 17:35:58.176: D/AndroidRuntime(9984): Shutting down VM
11-21 17:35:58.176: W/dalvikvm(9984): threadid=1: thread exiting with uncaught exception (group=0x41a21700)
11-21 17:35:58.191: E/AndroidRuntime(9984): FATAL EXCEPTION: main
11-21 17:35:58.191: E/AndroidRuntime(9984): android.database.sqlite.SQLiteException: cannot ATTACH database within transaction (code 1)
11-21 17:35:58.191: E/AndroidRuntime(9984): at android.database.sqlite.SQLiteConnection.nativeExecuteForChangedRowCount(Native Method)
11-21 17:35:58.191: E/AndroidRuntime(9984): at android.database.sqlite.SQLiteConnection.executeForChangedRowCount(SQLiteConnection.java:734)
11-21 17:35:58.191: E/AndroidRuntime(9984): at android.database.sqlite.SQLiteSession.executeForChangedRowCount(SQLiteSession.java:754)
11-21 17:35:58.191: E/AndroidRuntime(9984): at android.database.sqlite.SQLiteStatement.executeUpdateDelete(SQLiteStatement.java:64)
11-21 17:35:58.191: E/AndroidRuntime(9984): at android.database.sqlite.SQLiteDatabase.executeSql(SQLiteDatabase.java:1674)
11-21 17:35:58.191: E/AndroidRuntime(9984): at android.database.sqlite.SQLiteDatabase.execSQL(SQLiteDatabase.java:1603)
11-21 17:35:58.191: E/AndroidRuntime(9984): at com.kd7uiy.hamfinder.LogDatabaseHelper.onCreate(LogDatabaseHelper.java:27)
11-21 17:35:58.191: E/AndroidRuntime(9984): at android.database.sqlite.SQLiteOpenHelper.getDatabaseLocked(SQLiteOpenHelper.java:252)
11-21 17:35:58.191: E/AndroidRuntime(9984): at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:164)
我怎样才能让它工作?
最佳答案
我找到了一种让它发挥作用的方法,虽然我并不为此感到特别自豪,但它确实起到了作用。如果在附加数据库时不能处于事务中,则先结束事务。
db.setTransactionSuccessful();
db.endTransaction();
db.execSQL("ATTACH DATABASE ? AS names",new String[]{namesDb});
db.beginTransaction();
关于android - 使用 SQLiteOpenHelper 在 Android 中附加 sqlite 数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20133760/
我是 Android 开发的新手(坦率地说是整体开发),因此我一直在阅读 Commonsware Busy Coder 的指南。在阅读 SQLite 部分时,有几件事对我来说不是 %100 清楚。以下
我正在尝试在 Sqlite 数据库 中添加当前位置的纬度和经度。但是当我打开我的 Activity 时,它会崩溃并显示 android.database.sqlite.SQLiteOpenHelper
我无法理解我是如何错误地初始化数据库的: java.lang.NullPointerException at android.database.sqlite.SQLiteOpenHel
我有两个 Activity 和多个数据库类,我想在从 Activity1 到 Activity2 时传递附加信息中的数据库类名称,并在 Activity2 中加载 DatabaseAdapter 类。
我正在为我的(初学者/Android)应用程序实现一个数据库。 我不清楚是否 SQLiteOpenHelper 旨在创建数据库(物理上,写入.db/.sql 文件) super() 或者如果仍然由我来
我正在做一些测试,每次我调用 SQLiteOpenHelper.close()然后我尝试重新打开数据库,例如 SQLiteOpenHelper.getWritableDatabase()我得到异常 j
新手Q来自iPhone/MonoTouch C#背景 我有一个来自另一个项目的现有 SQLite 数据库文件。 我在哪里将数据库文件包含到我的 Eclipse 项目中以使其与应用程序一起部署。 我需要
我正在研究 Android SDK,以期为 friend 编写一个简单的应用程序(并且可能用于销售)。 此应用程序将在数据库中搜索关键字并将结果显示在屏幕上,我已经查看了 searchabul 词典和
如果一个应用程序中的多个 Activity 调用我的 SQLiteOpenHelper 的构造函数并将它们自己作为上下文参数,我可以确定它们都将访问同一个数据库吗? 例如,假设我有: package
我不知道是什么锁定了我的数据库。这个应用程序在生产中是全新的,我什至无法执行第一个将用户添加到数据库的操作。我有一个 DatabaseHandler 可以执行所有数据库操作。我的 Activity 正
通常,在 Activity 中,我是这样使用SQLiteOpenHelper DatabaseHandler mDbHelper = new DatabaseHandler(getBaseContex
我想用一些额外的方法(比如 getStreetsCursor)制作 SQLiteOpenHelper,这些方法从我的数据库返回数据。所以我写了这样的东西: public class DBHelper
我为学生创建了一个包含姓名、姓氏、分数字段的数据库,我确实成功地插入和查看了但我不知道如何进行更新和删除。 请在这里帮助我想根据ID进行更新和删除。 最佳答案 在 DatabaseHandler 类中
首先,我是 Android 应用程序的新手,并不是一个人在做这件事。我的队友在我处理这件事的同时进行了设计,并要求我设置数据库以及执行此操作的方法等等。 所以虽然大部分看起来没问题,但我说: Cont
为什么在 SQLiteOpenHelper 类变量的所有演示和教程中总是:public static final 看看: public static final String ORDER_ID
如果您扩展 SQLiteOpenHelper,您必须为构造函数使用上下文。我想知道是否有办法忽略它,并且能够在没有上下文的情况下使用数据库表。 或者至少是限制性的,我的意思是一种项目/类结构的方式,它
android.database.sqlite.SQLiteOpenHelper如果其构造函数的名称参数为 null,则提供使用内存数据库的能力: String: of the database fi
所以我想出了一些想法,我想知道它是否可以实现。 假设我有多个表(数据库模型),每个表都由某个类表示。我不习惯将单例模式与 open helper 一起使用,所以我创建了一些简单的类来提供数据库。我的想
我有一个即将发布的 Android 应用程序,我正在审查我的一些代码。我担心我的 SQLiteOpenHelper 的实现。具体来说,我想验证 onUpgrade 方法中的 oldVersion 和
我一直在使用 Android 和 SQLite 数据库开发应用程序。但我有一些问题。这是我的代码: SQLiteHelperMoney SQLiteHelperMoney1 = new
我是一名优秀的程序员,十分优秀!