Android中对于sqlite3中的数据查询?
PHP中文网
PHP中文网 2017-04-17 15:06:22
[Android讨论组]

目的读取sqlite3的数据。
数据

//select * from book;
1|Dan Brown|10.99|454|The Da vinvi Code
    SQLiteDatabase db = dbHelper.getWritableDatabase();
    Cursor cursor = db.query("book",null,null,null,null,null,null);
    if(cursor.moveToFirst()){
        do{
            String name = cursor.getString(cursor.getColumnIndex("name"));
            String author = cursor.getString(cursor.getColumnIndex("author"));
            int pages = cursor.getInt(cursor.getColumnIndex("page"));
            double price = cursor.getDouble(cursor.getColumnIndex("price"))
                Log.d("MainActivity","book name is" +name);
                Log.d("MainActivity","book author is"+author);
                Log.d("MainActivity","book pages is"+pages);
                Log.d("MainActivity","book price is"+price);
            }while (cursor.moveToNext());
            }

我自己调试发现是int pages = cursor.getInt(cursor.getColumnIndex("page"));发生了错误,错误显示信息

java.lang.IllegalStateException: Couldn't read row 0, col -1 from CursorWindow.  Make sure the Cursor is initialized correctly before accessing data from it.

建表


    create table book
    (
                id integer primary key autoincrement,
                author text,
                price real,
                pages integer,
                name text.
    )

我没有学过数据库除了语法可能出错其他不会有问题。

PHP中文网
PHP中文网

认证高级PHP讲师

全部回复(1)
PHP中文网

你的sql语句里:

pages integer,

但是你读取的时候是写

cursor.getColumnIndex("page")

你应该改成

cursor.getColumnIndex("pages")

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号