public void onClick(View v) {
/* 创建一个MySQLiteOpenHelper,该语句执行是不会创建或打开连接的 */
helper = new MySQLiteOpenHelper(MainActivity.this, "mydb.db", null, 1);
/* 调用MySQLiteOpenHelper的getWriteableDatabase()方法,创建或者打开一个连接 */
SQLiteDatabase sqlitedatabase = helper.getWritableDatabase();
Toast.makeText(MainActivity.this, "数据库创建成功", 1000).show();
}
});
/* 创建表 */
createTable.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
/* 创建一个MySQLiteOpenHelper,该语句执行是不会创建或打开连接的 */
helper = new MySQLiteOpenHelper(MainActivity.this, "mydb.db", null, 1);
/* 获取一个可写的SQLiteDatabase对象,创建或打开连接 */
SQLiteDatabase sqliteDatabase = helper.getWritableDatabase();
/* 创建两张表 */
sqliteDatabase.execSQL("create table student(id INTEGER PRIMARY KEY autoincrement,name text);");
sqliteDatabase.execSQL("create table "+MYTAB+"("+MYNAME+" text,"+MYSCORE+" integer);");
/* 小贴士 */
Toast.makeText(MainActivity.this, "数据表创建成功", 1000).show();
}
});
/* 插入数据 */
insertData.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
/* 连接数据库 *//* 数据库中有表 , 对表进行操作 */
SQLiteDatabase sqliteDatabase = helper.getWritableDatabase();
/* 给表添加数据: *//* 方式1: *//* 增加一条数据 */
sqliteDatabase.execSQL("insert into student(name) values('mike')");
/* 方式2: *//* 使用SQLiteDatabase 对象的insert()方法 */
/* 创建ContentValues对象 *//* 每次插入的时一条数据 */
ContentValues cv = new ContentValues();
cv.put("name", "mary"); /* key==列 value==值 */
sqliteDatabase.insert("student", null, cv);
cv.clear();
/* 对MYTAB进行数据添加 */
sqliteDatabase.execSQL("insert into "+MYTAB+" values('ray',95)");
sqliteDatabase.execSQL("insert into "+MYTAB+" values('tom',85)");
sqliteDatabase.execSQL("insert into "+MYTAB+" values('jone',90)");
cv.put(MYNAME, "jack");
cv.put(MYSCORE, 78);
sqliteDatabase.insert(MYTAB, null, cv);
cv.clear();
Toast.makeText(MainActivity.this, "数据插入成功", 1000).show();
}
});
/* 修改数据 *//* updateData点击事件监听器 */
updateData.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
/* 建立和数据库的连接,获取SQLiteDatabase对象 */
SQLiteDatabase sqliteDatabase = helper.getWritableDatabase();
/* 方式1:直接使用语句 */
//sqliteDatabase.execSQL("update student set name='mary key' where id=1");
/* 方式2:使用sqliteDatabase.update();方法 */
ContentValues cv = new ContentValues();
cv.put("name", "mary key"); /* 确定需要修改对应列的值 */
/* 参1:表名 ; 参2:ContentValues对象; 参3:where字句,相当于sql中where后面的语句, 是占位符 */
/* 参4:占位符的值; */
sqliteDatabase.update("student", cv, "id= ", new String[]{"1"});
Toast.makeText(MainActivity.this, "数据修改成功", 1000).show();
}
});
/* 删除数据 ; 设置deleteData点击事件监听器 */
deleteData.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
/* 与数据库建立联系,获得SQLiteDatabase的对象 */
SQLiteDatabase sqliteDatabase = helper.getWritableDatabase();
/* 使用sql语句直接进行删除 */
//sqliteDatabase.execSQL("");
/* 调用:SQLiteDatabase对象的delete()的方法删除数据 */
/* 参1:表名; 参2:条件语句; 参3:条件语句中对应占位符的值 */
sqliteDatabase.delete("student", "id= ", new String[]{"1"});
Toast.makeText(MainActivity.this, "数据删除成功", 1000).show();
}
});
/* 查看数据 *//* selectData点击事件监听器 */
selectData.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
/* 获取SQLiteDatabase的对象 */
SQLiteDatabase sqliteDatabase = helper.getReadableDatabase();
/* 调用SQLiteDatabase的query()方法