第一个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直接退出程序。
http://www.oschina.net/question/2352297_234880
建议贴日志,直接定位原因。
根据你的“第一个Activity跳到第二个Activity就崩溃”这句话,分析有以下几个原因:1.第二个Activity是否在清单文件中注册;2.空指针异常,你的textview对象是否为空,数据库取到的列表是否为空,你可以查查看看,打印一下从数据库获取的列表,在textview设置文本的地方加个try catch,打印一下异常信息等等。
先看一下数据库建好了没,还有个人觉得第二个activity中应该把mytable改成db
谢谢!在你们的提示下,我成功了!!!十分感谢各位大侠!!