2 chow stephen chow_stephen 于 2016.03.31 21:23 提问

一个Activity创建数据库,另一个Activity中调用数据库并用TextView显示

第一个Activity(创建数据库):

Db db = new Db(this);
    SQLiteDatabase dbWrite = db.getReadableDatabase();

    ContentValues cv = new ContentValues();
    cv.put("name", "小张");
    cv.put("sex", "男");
    dbWrite.insert("user", null, cv);

    cv = new ContentValues();
    cv.put("name", "小李");
    cv.put("sex", "女");
    dbWrite.insert("user", null, cv);
    dbWrite.close();

第二个Activity(查看数据库内容):

public class TryAnotherAty extends AppCompatActivity {

private TextView tv = null;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_try_another_aty);

    tv = (TextView) findViewById(R.id.tv);
    tv.setMovementMethod(ScrollingMovementMethod.getInstance());

    SQLiteDatabase dbRead = openOrCreateDatabase("mytable", Context.MODE_PRIVATE,null);
    Cursor  c = dbRead.query("user", null, null, null, null, null, null);

    while(c.moveToNext()){
        tv.append(getString(c.getColumnIndex("name")));
        tv.append(getString(c.getColumnIndex("sex")));
        tv.append("\n");
    }
}

Db.class:

public class Db extends SQLiteOpenHelper {

//必须要有构造函数
public Db(Context context) {
    super(context, "db", null, 1);
}

public void onCreate(SQLiteDatabase db) {
db.execSQL("create table user( name TEXT,sex TEXT )");
}

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

}

}

PS:真机测试时跳到第二个Acitvity直接退出程序。

6个回答

devmiao
devmiao   Ds   Rxr 2016.03.31 23:39
luochoudan
luochoudan   Ds   Rxr 2016.04.01 00:02

建议贴日志,直接定位原因。

u013268154
u013268154   2016.04.01 10:33

根据你的“第一个Activity跳到第二个Activity就崩溃”这句话,分析有以下几个原因:1.第二个Activity是否在清单文件中注册;2.空指针异常,你的textview对象是否为空,数据库取到的列表是否为空,你可以查查看看,打印一下从数据库获取的列表,在textview设置文本的地方加个try catch,打印一下异常信息等等。

qq_21717735
qq_21717735   2016.04.01 10:36

先看一下数据库建好了没,还有个人觉得第二个activity中应该把mytable改成db

CSDNXIAON
CSDNXIAON   2016.03.31 21:32

android 一个activity调用另一个activity,窗口化显示
----------------------同志你好,我是CSDN问答机器人小N,奉组织之命为你提供参考答案,编程尚未成功,同志仍需努力!

chow_stephen
chow_stephen   2016.04.06 21:48

谢谢!在你们的提示下,我成功了!!!十分感谢各位大侠!!

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!