- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试在我的应用程序中创建与 sqlite 的连接,但是如果我执行该应用程序,在 getWritableDatabase 行中,应用程序将强制关闭,我不明白发生了什么。
DBCore 类:
public class DBCore extends SQLiteOpenHelper{
private static final String DB_NAME = "";
private static final int DB_VERSION = 1;
public DBCore(Context ctx){
super(ctx, DB_NAME, null, DB_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
// TODO Auto-generated method stub
db.execSQL("create table user(code integer primary key, pass text not null);");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// TODO Auto-generated method stub
db.execSQL("drop table user;");
onCreate(db);
}
}
DBConnection 类:
public class DBLiteConnection {
private SQLiteDatabase db;
public DBLiteConnection(Context ctx){
DBCore dbcore = new DBCore(ctx);
db = dbcore.getWritableDatabase();
}
public void insert(int code, int pass){
ContentValues values = new ContentValues();
values.put("code", code);
values.put("pass", pass);
db.insert("user", null, values);
}
public void update(int code, int pass){
ContentValues values = new ContentValues();
values.put("code", code);
values.put("pass", pass);
db.update("user", values, "_code = "+code, null);
}
public void delete(int code, int pass){
ContentValues values = new ContentValues();
values.put("code", code);
values.put("pass", pass);
db.delete("user", "code = "+code, null);
}
public List<DBLiteUser> search(){
List<DBLiteUser> list = new ArrayList<DBLiteUser>();
String[] columns = new String[]{"code","pass"};
Cursor cursor = db.query("user", columns, null, null, null, null, null);
if(cursor.getCount() > 0){
cursor.moveToFirst();
DBLiteUser user = new DBLiteUser();
user.setCode(cursor.getInt(0));
user.setPass(cursor.getString(1));
list.add(user);
}
return list;
}
}
在“db = dbcore.getWritableDatabase();”行中强制关闭
日志:
02-02 11:35:21.778: E/AndroidRuntime(2593): FATAL EXCEPTION: main
02-02 11:35:21.778: E/AndroidRuntime(2593): Process: com.example.newpointerbi, PID: 2593
02-02 11:35:21.778: E/AndroidRuntime(2593): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.newpointerbi/com.example.newpointerbi.LoadingApp_Activity}: java.lang.StringIndexOutOfBoundsException: length=0; index=0
02-02 11:35:21.778: E/AndroidRuntime(2593): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2205)
02-02 11:35:21.778: E/AndroidRuntime(2593): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2255)
02-02 11:35:21.778: E/AndroidRuntime(2593): at android.app.ActivityThread.access$800(ActivityThread.java:142)
02-02 11:35:21.778: E/AndroidRuntime(2593): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1203)
02-02 11:35:21.778: E/AndroidRuntime(2593): at android.os.Handler.dispatchMessage(Handler.java:102)
02-02 11:35:21.778: E/AndroidRuntime(2593): at android.os.Looper.loop(Looper.java:136)
02-02 11:35:21.778: E/AndroidRuntime(2593): at android.app.ActivityThread.main(ActivityThread.java:5118)
02-02 11:35:21.778: E/AndroidRuntime(2593): at java.lang.reflect.Method.invokeNative(Native Method)
02-02 11:35:21.778: E/AndroidRuntime(2593): at java.lang.reflect.Method.invoke(Method.java:515)
02-02 11:35:21.778: E/AndroidRuntime(2593): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:792)
02-02 11:35:21.778: E/AndroidRuntime(2593): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:608)
02-02 11:35:21.778: E/AndroidRuntime(2593): at dalvik.system.NativeStart.main(Native Method)
02-02 11:35:21.778: E/AndroidRuntime(2593): Caused by: java.lang.StringIndexOutOfBoundsException: length=0; index=0
02-02 11:35:21.778: E/AndroidRuntime(2593): at java.lang.String.indexAndLength(String.java:584)
02-02 11:35:21.778: E/AndroidRuntime(2593): at java.lang.String.charAt(String.java:578)
02-02 11:35:21.778: E/AndroidRuntime(2593): at android.app.ContextImpl.validateFilePath(ContextImpl.java:2260)
02-02 11:35:21.778: E/AndroidRuntime(2593): at android.app.ContextImpl.openOrCreateDatabase(ContextImpl.java:1053)
02-02 11:35:21.778: E/AndroidRuntime(2593): at android.content.ContextWrapper.openOrCreateDatabase(ContextWrapper.java:256)
02-02 11:35:21.778: E/AndroidRuntime(2593): at android.database.sqlite.SQLiteOpenHelper.getDatabaseLocked(SQLiteOpenHelper.java:224)
02-02 11:35:21.778: E/AndroidRuntime(2593): at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:164)
02-02 11:35:21.778: E/AndroidRuntime(2593): at com.example.newpointerbi.DBLiteConnection.<init>(DBLiteConnection.java:16)
02-02 11:35:21.778: E/AndroidRuntime(2593): at com.example.newpointerbi.LoadingApp_Activity.onCreate(LoadingApp_Activity.java:19)
02-02 11:35:21.778: E/AndroidRuntime(2593): at android.app.Activity.performCreate(Activity.java:5275)
02-02 11:35:21.778: E/AndroidRuntime(2593): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
02-02 11:35:21.778: E/AndroidRuntime(2593): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2169)
02-02 11:35:21.778: E/AndroidRuntime(2593): ... 11 more
哪里出错了?
最佳答案
private static final String DB_NAME = "";
您需要提供一个有效的数据库文件名,而不是空字符串。
关于java - getWritableDatabase() SQLite 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28279067/
我已经使用 vue-cli 两个星期了,直到今天一切正常。我在本地建立这个项目。 https://drive.google.com/open?id=0BwGw1zyyKjW7S3RYWXRaX24tQ
您好,我正在尝试使用 python 库 pytesseract 从图像中提取文本。请找到代码: from PIL import Image from pytesseract import image_
我的错误 /usr/bin/ld: errno: TLS definition in /lib/libc.so.6 section .tbss mismatches non-TLS reference
我已经训练了一个模型,我正在尝试使用 predict函数但它返回以下错误。 Error in contrasts<-(*tmp*, value = contr.funs[1 + isOF[nn]])
根据Microsoft DataConnectors的信息我想通过 this ODBC driver 创建一个从 PowerBi 到 PostgreSQL 的连接器使用直接查询。我重用了 Micros
我已经为 SoundManagement 创建了一个包,其中有一个扩展 MediaPlayer 的类。我希望全局控制这个变量。这是我的代码: package soundmanagement; impo
我在Heroku上部署了一个应用程序。我正在使用免费服务。 我经常收到以下错误消息。 PG::Error: ERROR: out of memory 如果刷新浏览器,就可以了。但是随后,它又随机发生
我正在运行 LAMP 服务器,这个 .htaccess 给我一个 500 错误。其作用是过滤关键字并重定向到相应的域名。 Options +FollowSymLinks RewriteEngine
我有两个驱动器 A 和 B。使用 python 脚本,我在“A”驱动器中创建一些文件,并运行 powerscript,该脚本以 1 秒的间隔将驱动器 A 中的所有文件复制到驱动器 B。 我在 powe
下面的函数一直返回这个错误信息。我认为可能是 double_precision 字段类型导致了这种情况,我尝试使用 CAST,但要么不是这样,要么我没有做对...帮助? 这是错误: ERROR: i
这个问题已经有答案了: Syntax error due to using a reserved word as a table or column name in MySQL (1 个回答) 已关闭
我的数据库有这个小问题。 我创建了一个表“articoli”,其中包含商品的品牌、型号和价格。 每篇文章都由一个 id (ID_ARTICOLO)` 定义,它是一个自动递增字段。 好吧,现在当我尝试插
我是新来的。我目前正在 DeVry 在线学习中级 C++ 编程。我们正在使用 C++ Primer Plus 这本书,到目前为止我一直做得很好。我的老师最近向我们扔了一个曲线球。我目前的任务是这样的:
这个问题在这里已经有了答案: What is an undefined reference/unresolved external symbol error and how do I fix it?
我的网站中有一段代码有问题;此错误仅发生在 Internet Explorer 7 中。 我没有在这里发布我所有的 HTML/CSS 标记,而是发布了网站的一个版本 here . 如您所见,我在列中有
如果尝试在 USB 设备上构建 node.js 应用程序时在我的树莓派上使用 npm 时遇到一些问题。 package.json 看起来像这样: { "name" : "node-todo",
在 Python 中,您有 None单例,在某些情况下表现得很奇怪: >>> a = None >>> type(a) >>> isinstance(a,None) Traceback (most
这是我的 build.gradle (Module:app) 文件: apply plugin: 'com.android.application' android { compileSdkV
我是 android 的新手,我的项目刚才编译和运行正常,但在我尝试实现抽屉导航后,它给了我这个错误 FAILURE: Build failed with an exception. What wen
谁能解释一下?我想我正在做一些非常愚蠢的事情,并且急切地等待着启蒙。 我得到这个输出: phpversion() == 7.2.25-1+0~20191128.32+debian8~1.gbp108
我是一名优秀的程序员,十分优秀!