SQLiteOpenHelper的使用:

      首先声明一个DatabaseHelper类,这个类继承于SQLiteOpenHelper类,首先得有构造函数,声明DatabaseHelper类如下:

    //DatabaseHelper作为一个访问SQLite的助手类,提供两个方面的功能
    //第一,getReadableDatabase(),getWriteableDatabase()可以获得SQLiteDatabase对象,通过该对象对数据库进行操作
    //第二,提供了onCreate()和onUpgrade()两个回调函数,允许我们在创建和升级数据库时,进行自己的操作
    public class DatabaseHelper extends SQLiteOpenHelper{
      //在SQLiteOpenHelper的子类当中,必须有该构造函数
      //context为一个Activity对象,name表的名字,version数据库的版本
      private static final int VERSION = 1;
      public DatabaseHelper(Context context, String name, CursorFactory factory,int version) {
        super(context, name, factory, version);
        // TODO Auto-generated constructor stub
      }
      public DatabaseHelper(Context context,String name){
        //调用含三个参数的构造函数,即下一个自定义的构造函数
        this(context,name,VERSION);
      }
      public DatabaseHelper(Context context,String name,int version){
        //调用系统的构造函数,只不过给factory传入的值为空
        this(context,name,null,version);
      }
      //该函数是在第一次创建数据库的时候执行,实际上是第一次得到SQLiteDatabase对象的时候,才会调用该方法
      @Override
      public void onCreate(SQLiteDatabase db) {
        // TODO Auto-generated method stub
        //execSQL函数用于执行SQL语句
        db.execSQL("create table user(id int,name varchar(20))");
        //Log.d("myDebug", "My first Debug");
      }

      @Override
      public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        // TODO Auto-generated method stub
      }

    }

  如下定义了增删改查SQLite数据库的按钮的监听事件:

    class SQLButtonListener implements OnClickListener{

      @Override
      public void onClick(View v) {
        // TODO Auto-generated method stub
        if(v.getId() == R.id.createDatabase){
          //创建数据库,首次调用则执行onCreate方法
          DatabaseHelper dbHelper = new DatabaseHelper(OtherActivity.this,"test_zhanglei_db");
          SQLiteDatabase db = dbHelper.getReadableDatabase();
        }
        else if(v.getId() == R.id.updataDatabase){
          //更新当前数据库的版本号
          DatabaseHelper dbHelper = new DatabaseHelper(OtherActivity.this,"test_zhanglei_db",2);
        }
        else if(v.getId() == R.id.insertDatabase){    //插入按钮
          //生成ContentValue对象
          ContentValues values = new ContentValues();
          //向该对象中插入键值对,其中键是列名,值是希望插入的这一列的值,值必须与数据库的列的类型一致
          values.put("id", 1);
          values.put("name", "zhangsan");
          DatabaseHelper dbHelper = new DatabaseHelper(OtherActivity.this,"test_zhanglei_db",2);
          SQLiteDatabase db = dbHelper.getWritableDatabase();
          //调用insert方法,就可以将数据插入到数据库当中
          db.insert("user", null, values);
        }
        else if(v.getId() == R.id.updatatable){    //更新按钮
          //UPDATE table_name set XXCOL=xxx WHERE XXCOL=XX
          DatabaseHelper dbHelper = new DatabaseHelper(OtherActivity.this,"test_zhanglei_db",2);
          SQLiteDatabase db = dbHelper.getWritableDatabase();
          ContentValues values = new ContentValues();
          values.put("name", "zhangsanfeng");
          //第一个参数是更新的表名,第二个参数是一个ContentValues对象,第三个参数是where子句,?表示占位符,?有几个后面             的new String中就有几个参数
          db.update("user", values, "id=?", new String[]{("1")});
        }
        else if(v.getId() ==R.id.queryDatabase){      //查询按钮
          DatabaseHelper dbHelper = new DatabaseHelper(OtherActivity.this,"test_zhanglei_db",2);
          SQLiteDatabase db = dbHelper.getReadableDatabase();

          //表名,查询列名,where之后的子句,selection的参数,分组(groupby),分组的限制(Having),结果的排序(OrderBy)
          Cursor cursor = db.query("user", new String[]{"id","name"}, "id=?", new String[]{"1"}, null, null, null);
          while(cursor.moveToNext()){
            //getString(1)中的参数是表中的列名
            String name = cursor.getString(cursor.getColumnIndex("name"));
            textView.setText(textView.getText()+name);
          }
        }
      }
    }

SQLite关系型数据库的更多相关文章

  1. Android本地数据存储之SQLite关系型数据库 ——SQLiteDatabase

    数据库的创建,获取,执行sql语句: 框架搭建:dao 思考: 1.数据库保存在哪里? 2.如何创建数据库?如何创建表? 3.如何更新数据库?如何更改表的列数据? 4.如何获取数据库? 5.如何修改数 ...

  2. SQLite vs MySQL vs PostgreSQL:关系型数据库比较

    自1970年埃德加·科德提出关系模型之后,关系型数据库便开始出现,经过了40多年的演化,如今的关系型数据库种类繁多,功能强大,使用广泛.面对如此之多的关系型数据库,我们应该如何权衡找出适合自己应用场景 ...

  3. Python信息采集器使用轻量级关系型数据库SQLite

    1,引言Python自带一个轻量级的关系型数据库SQLite.这一数据库使用SQL语言.SQLite作为后端数据库,可以搭配Python建网站,或者为python网络爬虫存储数据.SQLite还在其它 ...

  4. SQLite -- 嵌入式关系型数据库

    SQLite -- 嵌入式关系型数据库 1.SQLite的数据类型:Typelessness(无类型) 1,能够保存不论什么类型的数据到表的随意列中 2.支持常见的类型如: NULL, VARCHAR ...

  5. 非关系型数据库(NoSql)

    最近了解了一点非关系型数据库,刚刚接触,觉得这是一个很好的方向,对于大数据 方面的处理,非关系型数据库能起到至关重要的地位.这里我主要是整理了一些前辈的经验,仅供参考. 关系型数据库的特点 1.关系型 ...

  6. android: SQLite创建数据库

    SQLite 是一款轻量级的关系型数据库,它的运算速度非常快, 占用资源很少,通常只需要几百 K 的内存就足够了,因而特别适合在移动设备上使用.SQLite 不仅支持标准的 SQL 语法,还遵循了数据 ...

  7. (转)Android学习笔记---SQLite介绍,以及使用Sqlite,进行数据库的创建,完成数据添删改查的理解

    原文:http://blog.csdn.net/lidew521/article/details/8655229 1.SQLite介绍:最大特点是,无数据类型;除了可以使用文件或SharedPrefe ...

  8. 关系型数据库工作原理-时间复杂度(翻译自Coding-Geek文章)

    本文翻译自Coding-Geek文章:< How does a relational database work>. 原文链接:http://coding-geek.com/how-dat ...

  9. 关系型数据库工作原理-事务管理(二)(翻译自Coding-Geek文章)

    本文翻译自Coding-Geek文章:< How does a relational database work>. 原文链接:http://coding-geek.com/how-dat ...

随机推荐

  1. JS中常遇到的浏览器兼容问题和解决方法

    今天整理了一下浏览器对JS的兼容问题,希望能给你们带来帮助,我没想到的地方请留言给我,我再加上: 常遇到的关于浏览器的宽高问题: //以下均可console.log()实验 var winW=docu ...

  2. 代码编辑器Sublime Text 3 免费使用方法与简体中文汉化包下载

    Sublime Text这款代码编辑器是Jeff 一直都在使用的,前段时间转用到版本3,因为感觉Sublime Text 3 启动速度更加快,运行更加流畅——虽然3 还是在Beta 阶段.下面就直接分 ...

  3. mysql 命令行还原备份数据库

    通常数据库还原备份可以通过navicat等数据库管理工具进行,只需要简单的导出导入就行了,但遇到有索引外键的数据库,数据库管理工具运行.sql文件会报错,这时候可以尝试命令行导入,亲测可以成功 MyS ...

  4. 一鼓作气 博客--第四篇 note4

    1.元祖允许重复数据.只读元组,列表,元祖没有增删改查,比如身份证列表,不允许修改,就存成 元祖. 2. 字典 key-value对 特性: 无顺序 去重 查询速度快,比列表快多了 比list占用内存 ...

  5. java身份证验证

    import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Calendar; impor ...

  6. js测试题

    (function(){ return typeof arguments;})();"object" var f = function g(){ return 23; };type ...

  7. 日常办公工具利器 notepad++

    日常办公工具利器 notepad++ 文本内容比较 Notepad++ https://notepad-plus-plus.org/ http://jingyan.baidu.com/article/ ...

  8. Windows环境安装Linux系统及JDK部署

    前言 由于我的笔记本有点问题,所以这周系统包括所有硬盘全部重装了,原来的Linux虚拟机都没了,因此才有了这篇文章和各位朋友们分享. 由于Linux环境的优越性(开源.低成本.安全性好.网络功能强大) ...

  9. Btree 索引

    Btree 索引 索引是帮助数据库高效获取数据的一种数据结构,通过提取句子主干,就可以得到索引的本质. m-way查找树 如果想了解Btree,需要首先了解m-way数据结构. m-way查找树是是一 ...

  10. 关于分工的思考 (Thoughts on Division of Labor)

    Did you ever have the feeling that adding people doesn't help in software development? Did you ever ...