chow_stephen 2016-03-31 13:23 采纳率: 0%
浏览 3161

一个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直接退出程序。

  • 写回答

5条回答 默认 最新

  • devmiao 2016-03-31 15:39
    关注
    评论

报告相同问题?

悬赏问题

  • ¥100 求数学坐标画圆以及直线的算法
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 自己瞎改改,结果现在又运行不了了
  • ¥15 链式存储应该如何解决
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站