设为首页 收藏本站
查看: 1575|回复: 0

[经验分享] Android学习笔记(三 数据库SQLITE的基本操作)

[复制链接]

尚未签到

发表于 2016-12-1 09:13:51 | 显示全部楼层 |阅读模式
  SQLITE是android自带的标准数据库,它支持SQL语句,是一个轻量级的嵌入式数据库.
  学习SQLITE首先需要了解一些知识点:
  1. SQLiteDatabase
  一个SQLiteDatabase的实例代表一个SQLite的数据库,通过SQLiteDatabase实例的一些方法,我们可以执行SQL语句,进行对数据库的增删改查操作。数据库对于一个应用来说是私有的,并且在一个应用当中,名字也是唯一的。
  2. SQLiteOpenHelper
  这是一个抽象类。当在程序中调用这个类的方法getWritableDatebase()或者getReadableDatebase()方法的时候,如果当时没有数据,那么android系统就会自动生成一个数据库。对于SQLiteOpenHelper我们通常需要继承它,并实现它里面的3个函数
  (1)onCreate
  在数据库第一次生成的时候会调用这个方法,一般我们在这个方法里边生成数据库表
  (2)onUpgrade
  当数据库需要升级的时候,Android系统会自动调用这个方法,一般我们在这个方法里面删除数据库表,并建立新的数据库表。并且还可以根据应用需求进行其它操作。
  (3)onOpen
  这是当打开数据库时的回调函数,一般也不会用到。
  下面来展示一下操作数据库的具体代码
  public class ActivityMain extends Activity {
 OnClickListener listener1 = null;
 OnClickListener listener2 = null;
 OnClickListener listener3 = null;
 OnClickListener listener4 = null;
 OnClickListener listener5 = null;
  Button button1;
 Button button2;
 Button button3;
 Button button4;
 Button button5;
  DatabaseHelper mOpenHelper;
  private static final String DATABASE_NAME ="dbForTest.db";
 private static final int DATABASE_VERSION =1;
 private static final String TABLE_NAME ="diary";
 private static final String TITLE ="title";
 private static final String BODY = "body";
  private static class DatabaseHelper extendsSQLiteOpenHelper {
  DatabaseHelper(Context context){
   super(context,DATABASE_NAME, null, DATABASE_VERSION);
  }
  @Override
  public voidonCreate(SQLiteDatabase db) {
  String sql= "CREATE TABLE " + TABLE_NAME + " (" + TITLE
     +" text not null, " + BODY + " text not null " + ");";
   System.out.print(sql);
   Log.i("haiyang:createDB=",sql);
   db.execSQL(sql);
  }
  @Override
  public voidonUpgrade(SQLiteDatabase db, int oldVersion, int newVersion){
  }
 }
  @Override
 public void onCreate(Bundle savedInstanceState){
  super.onCreate(savedInstanceState);
  setContentView(R.layout.main);
  prepareListener();
  initLayout();
  mOpenHelper = newDatabaseHelper(this);
  }
  private void initLayout() {
  button1 = (Button)findViewById(R.id.button1);
  button1.setOnClickListener(listener1);
  button2 = (Button)findViewById(R.id.button2);
  button2.setOnClickListener(listener2);
  button3 = (Button)findViewById(R.id.button3);
  button3.setOnClickListener(listener3);
  button4 = (Button)findViewById(R.id.button4);
  button4.setOnClickListener(listener4);
  button5 = (Button)findViewById(R.id.button5);
  button5.setOnClickListener(listener5);
  }
  private void prepareListener() {
  listener1 = newOnClickListener() {
   public voidonClick(View v) {
    CreateTable();
   }
  };
  listener2 = newOnClickListener() {
   public voidonClick(View v) {
    dropTable();
   }
  };
  listener3 = newOnClickListener() {
   public voidonClick(View v) {
    insertItem();
   }
  };
  listener4 = newOnClickListener() {
   public voidonClick(View v) {
    deleteItem();
   }
  };
  listener5 = newOnClickListener() {
   public voidonClick(View v) {
    showItems();
   }
  };
 }
  
 private void CreateTable() {
  SQLiteDatabase db =mOpenHelper.getWritableDatabase();
  String sql = "CREATE TABLE " +TABLE_NAME + " (" + TITLE
    +" text not null, " + BODY + " text not null " + ");";
  Log.i("haiyang:createDB=",sql);
  try {
   db.execSQL("DROPTABLE IF EXISTS diary");
   db.execSQL(sql);
   setTitle("数据表成功重建");
  } catch (SQLException e){
   setTitle("数据表重建错误");
  }
 }
  
 private void dropTable() {
  SQLiteDatabase db =mOpenHelper.getWritableDatabase();
  String sql = "drop table " +TABLE_NAME;
  try {
   db.execSQL(sql);
   setTitle("数据表成功删除:"+ sql);
  } catch (SQLException e){
   setTitle("数据表删除错误");
  }
 }
  
 private void insertItem() {
  SQLiteDatabase db =mOpenHelper.getWritableDatabase();
  String sql1 = "insert into " +TABLE_NAME + " (" + TITLE + ", " + BODY
    +") values('haiyang', 'android的发展真是迅速啊');";
  String sql2 = "insert into " +TABLE_NAME + " (" + TITLE + ", " + BODY
    +") values('icesky', 'android的发展真是迅速啊');";
  try {
   Log.i("haiyang:sql1=",sql1);
   Log.i("haiyang:sql2=",sql2);
   db.execSQL(sql1);
   db.execSQL(sql2);
   setTitle("插入两条数据成功");
  } catch (SQLException e){
   setTitle("插入两条数据失败");
  }
 }
  
 private void deleteItem() {
  try {
   SQLiteDatabasedb = mOpenHelper.getWritableDatabase();
   db.delete(TABLE_NAME," title = 'haiyang'", null);
   setTitle("删除title为haiyang的一条记录");
  } catch (SQLException e) {
  }
  }
  
 private void showItems() {
  SQLiteDatabase db =mOpenHelper.getReadableDatabase();
  String col[] = { TITLE, BODY};
  Cursor cur =db.query(TABLE_NAME, col, null, null, null, null, null);
  Integer num =cur.getCount();
  setTitle(Integer.toString(num)+ " 条记录");
 }
}
  在上述代码中
  DataBaseHelper类继承了SQLieOpenHelper类,并且重写了onCreate和onUpgrade方法。
  在onCreate方法中我们首先构造了一条SQL语句,然后调用了db.execSQL(sql)执行SQL语句。生成了一个表
  因为目前我们还不需要升级数据库,所以我们在onUpgrade()函数里面没有执行任何操作。
  ==============================================================================================
  下面对应的就是增删改查方法
  主要说下查的方法:
  如前面知识点所说,先创建一个SQLiteDatebase的对象,得到一个可写的数据库.
  Sring col[]={TITLE,BODY};
  SQLiteDatabase db =mOpenHelper.getReadableDatabase();
  Cursor cur = db.query(TABLE_NAME, col, null,null, null, null, null);
  这条语句将查询到的数据放到一个Cursor中。这个Cursor中封装了这个数据表TABLE_NAME当中的所有条列。下面具体说下query()方法:
  第一个参数是数据库里边表的名字。
  第二个参数是我们想要返回数据包含的列的信息。如上面代码所示我们把列名存放在名为col的数组里
  第三个参数为selection,相当于SQL语句的where部分,如果想返回所有的数据,那么就直接设置为null.
  第四个参数为selectionArgs.在selection部分,有可能用到"?",那么在selectionArgs定义的字符串会代替selection中的"?".
  第五个参数为groupBy。定义查询出来的数据是否分组,如果为null,则说明不需要分组。
  第六个参数为having。相当于SQL语句当中的having部分。
  第七个参数为orderBy。这个就是排序。
  最后 Integernum=cur.getCount()语句通过getCount()方法,可以得到Cursor当中数据的个数。
  对于Cursor的理解:
  Cursor本身是指针的意思。在android中是一个非常有用的接口,通过Cursor我们可以对从数据库查询出来的结果集进行随机的读写访问。
  一个简单的对数据库操作的demo介绍完了,最后需要说明的是在Android的设计哲学里鼓励开发者使用内部类,这样不但使用方便,而且执行效率也高。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-307997-1-1.html 上篇帖子: 给sqlite数据库加密的两种方法 下篇帖子: android sqlite SQLiteDatabase 操作大全 不看后悔!必收藏!看后精通SQLITE (第三部分,完整代码)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表