- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
无法从具有 1 行 11 列的 CursorWindow 读取第 0 行第 11 列。
这是我想从数据库中读取数据时(登录时)遇到的错误。它还说“应用程序停止工作”。这是 JSON 响应:
E/JSON﹕ {"tag":"login","success":1,"error":0,"user":{"fname":"somefirstname","lname":"somelastname","email":"some@email.com","uname":"someuser","address":"someaddress","tel":"somephone","dob":"15\/01\/1997","ptc":"somepostco","id":"3","created_at":"2013-12-28 01:20:33"}}
12-27 17:23:14.602
前一个错误的下一个错误是“无法从 CursorWindow 读取第 0 行,第 11 列”。它是 created_at 字符串,当我删除它时,它登录时不会崩溃,但它会读取错误的数据...
这是我的 DatabaseHandler.java
public class DatabaseHandler extends SQLiteOpenHelper {
// All Static variables
// Database Version
private static final int DATABASE_VERSION = 2;
// Database Name
private static final String DATABASE_NAME = "login";
// Login table name
private static final String TABLE_LOGIN = "member";
// Login Table Columns names
private static final String KEY_ID = "id";
private static final String KEY_FIRSTNAME = "fname";
private static final String KEY_LASTNAME = "lname";
private static final String KEY_EMAIL = "email";
private static final String KEY_USERNAME = "uname";
private static final String KEY_UID = "uid";
private static final String KEY_ADDRESS = "address";
private static final String KEY_TELEPHONE = "tel";
private static final String KEY_DATEOFBIRTH = "dob";
private static final String KEY_POSTCODE = "ptc";
private static final String KEY_CREATED_AT = "created_at";
public DatabaseHandler(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
// Creating Tables
@Override
public void onCreate(SQLiteDatabase db) {
String CREATE_LOGIN_TABLE = "CREATE TABLE " + TABLE_LOGIN + "("
+ KEY_ID + " INTEGER PRIMARY KEY,"
+ KEY_FIRSTNAME + " TEXT,"
+ KEY_LASTNAME + " TEXT,"
+ KEY_EMAIL + " TEXT UNIQUE,"
+ KEY_USERNAME + " TEXT,"
+ KEY_UID + " TEXT,"
+ KEY_ADDRESS + " TEXT,"
+ KEY_TELEPHONE + " TEXT,"
+ KEY_DATEOFBIRTH + " TEXT,"
+ KEY_POSTCODE + " TEXT,"
+ KEY_CREATED_AT + " TEXT" + ")";
db.execSQL(CREATE_LOGIN_TABLE);
}
// Upgrading database
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// Drop older table if existed
db.execSQL("DROP TABLE IF EXISTS " + TABLE_LOGIN);
// Create tables again
onCreate(db);
}
/**
* Storing user details in database
* */
public void addUser(String fname, String lname, String email, String uname, String uid, String address, String tel, String ptc, String dob, String created_at) {
SQLiteDatabase db = this.getWritableDatabase();
ContentValues values = new ContentValues();
values.put(KEY_FIRSTNAME, fname); // FirstName
values.put(KEY_LASTNAME, lname); // LastName
values.put(KEY_EMAIL, email); // Email
values.put(KEY_USERNAME, uname); // UserName
values.put(KEY_UID, uid); // Email
values.put(KEY_ADDRESS, address); // Address
values.put(KEY_TELEPHONE, tel); // Telephone
values.put(KEY_DATEOFBIRTH, dob); // Date of Birth
values.put(KEY_POSTCODE, ptc); // ZIP code
values.put(KEY_CREATED_AT, created_at); // Created At
// Inserting Row
db.insert(TABLE_LOGIN, null, values);
db.close(); // Closing database connection
}
/**
* Getting user data from database
* */
public HashMap<String, String> getUserDetails(){
HashMap<String,String> user = new HashMap<String,String>();
String selectQuery = "SELECT * FROM " + TABLE_LOGIN;
SQLiteDatabase db = this.getReadableDatabase();
Cursor cursor = db.rawQuery(selectQuery, null);
// Move to first row
cursor.moveToFirst();
if(cursor.getCount() > 0){
user.put("id", cursor.getString(1)); // id - uid
user.put("username", cursor.getString(2)); // uname - username
user.put("email", cursor.getString(4));
user.put("fname", cursor.getString(5));
user.put("lname", cursor.getString(6));
user.put("dob", cursor.getString(7));
user.put("tel", cursor.getString(8));
user.put("address", cursor.getString(9));
user.put("ptc", cursor.getString(10));
//user.put("created_at", cursor.getString(11));
}
cursor.close();
db.close();
// return user
return user;
}
/**
* Getting user login status
* return true if rows are there in table
* */
public int getRowCount() {
String countQuery = "SELECT * FROM " + TABLE_LOGIN;
SQLiteDatabase db = this.getReadableDatabase();
Cursor cursor = db.rawQuery(countQuery, null);
int rowCount = cursor.getCount();
db.close();
cursor.close();
// return row count
return rowCount;
}
/**
* Re crate database
* Delete all tables and create them again
* */
public void resetTables(){
SQLiteDatabase db = this.getWritableDatabase();
// Delete All Rows
db.delete(TABLE_LOGIN, null, null);
db.close();
}
}
这是我的 .sql 数据库
CREATE TABLE `login`.`member` (
`id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
`username` VARCHAR(30) NOT NULL,
`encrypted_password` VARCHAR(80) NOT NULL,
`email` VARCHAR(50) NOT NULL,
`fname` VARCHAR(30) NOT NULL,
`lname` VARCHAR(30) NOT NULL,
`dob` VARCHAR(10) NOT NULL,
`tel` VARCHAR(15) NOT NULL,
`address` VARCHAR(50) NOT NULL,
`ptc` VARCHAR(10) NOT NULL,
`salt` VARCHAR(10) NOT NULL,
`created_at` datetime DEFAULT NULL
) ENGINE = InnoDB;
这一切都是在我更新我的数据库时发生的,以前它只有用户名、fname、lname、id 和 created_at 字符串,然后我添加了一些其他字符串,这就发生了。请记住,在它正确读取应用程序中我的帐户信息中的数据之前,您不会说我的标签/ID 错误等...
public HashMap<String, String> getUserDetails(){
HashMap<String,String> user = new HashMap<String,String>();
String selectQuery = "SELECT * FROM " + TABLE_LOGIN;
SQLiteDatabase db = this.getReadableDatabase();
Cursor cursor = db.rawQuery(selectQuery, null);
// Move to first row
cursor.moveToFirst();
if(cursor.getCount() > 0){
user.put("id", cursor.getString(1));
user.put("username", cursor.getString(2));
user.put("email", cursor.getString(3));
user.put("fname", cursor.getString(4));
user.put("lname", cursor.getString(5));
user.put("dob", cursor.getString(6));
user.put("tel", cursor.getString(7));
user.put("address", cursor.getString(8));
user.put("ptc", cursor.getString(9));
user.put("created_at", cursor.getString(10));
}
cursor.close();
db.close();
// return user
return user;
}
这是我的登录API
$response["success"] = 1;
$response["user"]["fname"] = $user["fname"];
$response["user"]["lname"] = $user["lname"];
$response["user"]["email"] = $user["email"];
$response["user"]["uname"] = $user["username"];
$response["user"]["address"] = $user["address"];
$response["user"]["tel"] = $user["tel"];
$response["user"]["dob"] = $user["dob"];
$response["user"]["ptc"] = $user["ptc"];
$response["user"]["id"] = $user["id"];
$response["user"]["created_at"] = $user["created_at"];
echo json_encode($response);
最佳答案
我看到一个问题,在您的 Android SQLite CREATE_LOGIN_TABLE
语句中,没有创建列 encrypted_password
。那么您的表只有 11 列,这导致最大索引 10。没有索引为 11 的列,也没有名称为 encrypted_password
并调用 cursor.getString(11);
的列是强制关闭您的应用程序的错误原因。
所有读取数据库数据的问题都是硬编码索引,这些索引与创建列的顺序不匹配。当您在 onCreateDatabase()
方法上创建表时,列顺序是:
等由于创建表语句中列名的顺序。
在您的 getUserDetails
方法中,您使用索引为 5 的 fname、索引为 6 的 lname 等。硬编码索引与创建表语句中列的顺序不匹配,您使用用户名和 ID值而不是 fname 和 lname。其他列也类似。
为了正确使用列索引,您应该在 Cursor
上使用 getColumnIndex(String columnName)
方法而不是硬编码索引。例如:
int fnameIndex = cursor.getColumnIndex(KEY_FIRSTNAME);
String fname = cursor.getString(fnameIndex);
这是您可以在 getUserDetails()
方法中使用的代码 fragment :
user.put("id", cursor.getString(cursor.getColumnIndex(KEY_ID))); // id - uid
user.put("username", cursor.getString(cursor.getColumnIndex(KEY_USERNAME))); // uname - username
user.put("email", cursor.getString(cursor.getColumnIndex(KEY_EMAIL)));
user.put("fname", cursor.getString(cursor.getColumnIndex(KEY_FIRSTNAME)));
user.put("lname", cursor.getString(cursor.getColumnIndex(KEY_LASTNAME)));
user.put("dob", cursor.getString(cursor.getColumnIndex(KEY_DATEOFBIRTH)));
user.put("tel", cursor.getString(cursor.getColumnIndex(KEY_TELEPHONE)));
user.put("address", cursor.getString(cursor.getColumnIndex(KEY_ADDRESS)));
user.put("ptc", cursor.getString(cursor.getColumnIndex(KEY_CREATED_AT)));
关于Android,SQLITE : Failed to read row 0, 来自 CursorWindow 的第 11 列,它有 1 行,11 列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20808722/
我有一个阅读器,其中包含有关 51*51 网格的信息,其中网格上的每个点都由 f32 表示。 .我想将这些数据读入一个向量,以便我可以轻松处理它: pub fn from_reader(reader:
我重新启动了 SQL Server 2005 并运行了统计 IO 的查询。 我得到了这些结果:表“xxx”。扫描计数 1,逻辑读取 789,物理读取 3,预读读取 794,... 预读读取数是读取并放
在 CLHS 中,我为 :read-only x 读到:“当 x 为真时,这指定不能更改此插槽;它将始终包含构造时提供的值。” 我可以做到这一点(CCL、SBCL): CL-USER> (defstr
让我们考虑一下这句话(Total Store Ordering): reads are ordered before reads, writes before writes, and reads be
我正在开发一个 SMTP 库,它使用缓冲读取器通过网络读取行。 我想要一种安全的方式来从网络读取数据,而不依赖于 Rust 内部机制来确保代码按预期工作。具体来说,我想知道 Read trait 是否
我不清楚所有这些读取字符串函数之间的关系。嗯,很明显clojure.core/read-string可以读取 pr[n] 输出的任何序列化字符串甚至 print-dup .也很清楚clojure.ed
所以我做了这个功能,就像倒计时一样。我想在倒计时减少时读取命令。我的大问题是让 read() 在倒计时减少时等待输入。如您所见,我尝试使用 select() 但在第一个 printf 之后("time
这是我vue3+echart5 遇到的报错:Cannot read properties of undefined (reading ‘type‘) 这个问题需要搞清楚两个关键方法: toRaw: 作
下图中,左边是C代码,右边是未优化的LLVM IR形式。 The Figure 在 IR 上运行 MemoryDependenceAnalysis 可查找内存依赖性。原始代码及其 IR 等效代码中
这个问题在这里已经有了答案: Read values into a shell variable from a pipe (17 个答案) 关闭 3 年前。 我一直在尝试像这样从程序输出中读取环境变
当我输入相同的整数时,如何将整数转换为与使用 read(0,buff,nbytes) 获得的缓冲区相同的值/编码字符?我正在尝试编写类似 read() 的东西,但用整数数据代替读取到缓冲区的文件描述符
This question already has answers here: Closed 2 years ago. Read input in bash inside a while loop (
我正在尝试处理来自 MySQL 数据库的一些数据(主要是 double 值)。我收到此错误消息: Invalid attempt to access a field before calling Re
我正在制作一个简单的 TCP/IP 套接字应用 这样做有什么不同: DataInputStream in = new DataInputStream(clientSocket.getInputStre
我操作API服务器。 手机APP访问API服务器时,有时会出现该异常。 我尝试在测试服务器上进行测试,但无法重现。(我改变了apache和tomcat的连接时间。) 有什么问题?? 我该如何解决这个问
我在段落末尾使用“阅读更多”只是为了提醒像P.T.O一样的用户 为什么会有问题? 最佳答案 您必须明白,许多屏幕阅读器用户不会等到整个页面都读给他们听。他们使用键盘快捷键在页面中导航。 JAWS(可以
我已将我的 Angular 应用程序从 12 版本升级到 13 版本。我在单元测试运行期间开始遇到此错误。 Chrome Headless 94.0.4606.61 (Windows 10) AppC
我正在尝试为以下组件编写一个。我正在使用 queryParams 然后使用 switchmap 来调用服务。这是 url 的样子: http://localhost:4200/test-fee/det
我的代码有什么问题? Uncaught TypeError: Cannot read properties of undefined (reading 'remove') 和 Uncaught Typ
我在我的 React 应用程序中遇到了这个问题。 类型错误:无法读取未定义的属性(读取“requestContent”) 我在我的应用程序中使用 commercejs。代码指向 isEmpty=!ca
我是一名优秀的程序员,十分优秀!