在Android应用程序中使用SQLite数据库以及怎么用(四)

2014-11-24 09:53:16 · 作者: · 浏览: 1
ClickListener(new OnClickListener() {

  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()方法