Android采用关系型数据库SQLite3,它是一个支持SQL轻量级的嵌入式数据库,在嵌入式操作系统上有很广泛的应用,WM采用的也是SQLite3

关于过于、原理方面的东西在这篇文章里不会提到,但是如果你想能够快速的学会操作SQLite3,那这就是你要找的文章!

首先,我们看一下api,所有数据库相关的接口、类都在android.database和android.database.sqlite两个包下,虽然只有两个包,但是如果你英文不好或是太懒的话也要迷茫一段时间,其实,我们真正用的到的没有几个!

1、SQLiteOpenHelper (android.database.sqlite.SQLiteOpenHelper)

这是一个抽象类,关于抽象类我们都知道,如果要使用它,一定是继承它!

这个类的方法很少,有一个构造方法

SQLiteOpenHelper(android.content.Context context,                 java.lang.String name,android.database.sqlite.SQLiteDatabase.CursorFactory factory, int version);
        参数不做过多的解释,CursorFactory一般直接传null就可以

public void onCreate(SQLiteDatabase db)
        此方法在创建数据库是被调用,所以,应该把创建表的操作放到这个方法里面,一会儿在后面我们会再详细的说如何创建表
        public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion)

从方法名上我们就能知道这个方法是执行更新的,没错,当version改变是系统会调用这个方法,所以在这个方法里应该执行删除现有表,然后手动调用onCreate的操作

SQLiteDatabase getReadableDatabase()

获取可读的SQLiteDatabase对象

SQLiteDatabase getWritableDatabase()  
        获取可写的SQLiteDatabase对象

2、SQLiteDatabase(android.database.sqlite.SQLiteDatabase)

关于操作数据库的工作(增、删、查、改)都在这个类里
        execSQL(sql)
        执行SQL语句,用这个方法+SQL语句可以非常方便的执行增、删、查、改

除此之外,Android还提供了功过方法实现增、删、查、改
        long insert(TABLE_NAME, null, contentValues)添加记录
        int delete(TABLE_NAME, where, whereValue)删除记录
        int update(TABLE_NAME, contentValues, where, whereValue) 更新记录
        Cursor query(TABLE_NAME, null, null, null, null, null, null) 查询记录

除此之外,还有很多方法,如:beginTransaction()开始事务、endTransaction()结束事务...有兴趣的可以自己看api,这里就不多赘述了
        
        3、Cursor(android.database.Cursor)

游标(接口),这个很熟悉了吧,Cursor里的方法非常多,常用的有:
        boolean moveToPosition(position)将指针移动到某记录
        getColumnIndex(Contacts.People.NAME)按列名获取id
        int  getCount()获取记录总数
        boolean requery()重新查询
        boolean  isAfterLast()指针是否在末尾
        boolean  isBeforeFirst()时候是开始位置
        boolean  isFirst()是否是第一条记录
        boolean  isLast()是否是最后一条记录
        boolean  moveToFirst()、        boolean  moveToLast()、        boolean  moveToNext()同moveToPosition(position)

4、SimpleCursorAdapter(android.widget.SimpleCursorAdapter)
        
        也许你会奇怪了,之前我还说过关于数据库的操作都在database和database.sqlite包下,为什么把一个Adapter放到这里,如果你用过Android的SQLite3,你一定会知道
,这是因为我们对数据库的操作会经常跟列表联系起来

经常有朋友会在这出错,但其实也很简单
        SimpleCursorAdapter adapter =    new SimpleCursorAdapter(
                this,
                R.layout.list, 
                myCursor,
                new String[] {DB.TEXT1,DB. TEXT2},
                new int[]{ R.id.listTextView1,R.id.listTextView2 });
           myListView.setAdapter(adapter);
        一共5个参数,具体如下:
        参数1:Content
        参数2:布局
        参数3:Cursor游标对象
        参数4:显示的字段,传入String[]
        参数5:显示字段使用的组件,传入int[],该数组中是TextView组件的id
        到这里,关于数据库的操作就结束了,但是到目前为止我只做了翻译的工作,有些同学可能还是没有掌握,放心,下面我们一起顺着正常开发的思路理清一下头绪!
        前面的只是帮没做过的朋友做下普及,下面才是你真正需要的!
        一、写一个类继承SQLiteOpenHelpe
                public class DatabaseHelper extends SQLiteOpenHelper
                构造方法:
                DatabaseHelper(Context context) {
                        super(context, DATABASE_NAME, null, DATABASE_VERSION);
                }
                在onCreate方法里写建表的操作
                        public void onCreate(SQLiteDatabase db) {
                        
                                String sql = "CREATE TABLE tb_test (_id INTEGER DEFAULT '1' NOT NULL PRIMARY KEY AUTOINCREMENT,class_jb TEXT  NOT NULL,class_ysbj TEXT  NOT NULL,title TEXT  NOT NULL,content_ysbj TEXT  NOT NULL)";
                                
                                db.execSQL(sql);//需要异常捕获
                        }
                在onUpgrade方法里删除现有表,然后手动调用onCtreate创建表
                        public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
                                String sql = "drop table "+tbname;
                                db.execSQL(sql);
                                onCreate(db);
                        }
                
                定义对表增、删、查、改的方法,这里用的是SQLiteOpenHelper提供的方法,也可以用sql语句实现,都是一样的
                关于获取可读/可写SQLiteDatabase,我不说大家也应该会想到,只有查找才会用到可读的SQLiteDatabase
                        /**
                         * 添加数据
                         */
                        public long insert(String tname, int tage, String ttel){
                                SQLiteDatabase db= getWritableDatabase();//获取可写SQLiteDatabase对象
                                //ContentValues类似map,存入的是键值对
                                       ContentValues contentValues = new ContentValues();
                                       contentValues.put("tname", tname);
                                contentValues.put("tage", tage);
                                       contentValues.put("ttel", ttel);
                                return db.insert(tbname, null, contentValues);
                                }
                        /**
                         * 删除记录
                         * @param _id
                         */
                        public void delete(String _id){
                                SQLiteDatabase db= getWritableDatabase();
                                db.delete(tbname, 
                                        "_id=?", 
                                        new String[]{_id});
                        }
                        /**
                         * 更新记录的,跟插入的很像
                         */
                        public void update(String _id,String tname, int tage, String ttel){
                                SQLiteDatabase db= getWritableDatabase();
                                        ContentValues contentValues = new ContentValues();
                                        contentValues.put("tname", tname);
                                        contentValues.put("tage", tage);
                                       contentValues.put("ttel", ttel);
                                     db.update(tbname, contentValues, 
                                        "_id=?", 
                                        new String[]{_id});
                        }
                        /**
                         * 查询所有数据 
                         * @return Cursor
                         */
                        public Cursor select(){
                                SQLiteDatabase db = getReadableDatabase();
                                        return db.query(
                                                tbname, 
                                                new String[]{"_id","tname","tage","ttel","taddr"}, 
                                                null, 
                                                null, null, null, "_id desc");
                        }
                        关于db.query方法的参数,有很多,为了防止大家弄乱,我简单说一下
                        参数1:表名
                        参数2:返回数据包含的列信息,String数组里放的都是列名
                        参数3:相当于sql里的where,sql里where后写的内容放到这就行了,例如:tage>?
                        参数4:如果你在参数3里写了?(知道我为什么写tage>?了吧),那个这里就是代替?的值 接上例:new String[]{"30"}
                        参数5:分组,不解释了,不想分组就传null
                        参数6:having,想不起来的看看SQL
                        参数7:orderBy排序

到这里,你已经完成了代码最多的第一步!我们来看看都用到了那些类:
                        SQLiteOpenHelper我们继承使用的
                        SQLiteDatabase增删查改都离不开它,即使你直接用sql语句,也要用到execSQL(sql)

二、这里无非是对DatabaseHelper类定义方法的调用,没什么可说的,不过我还是对查询再唠叨几句吧
                        Android查询出来的结果一Cursor形式返回
                                 cursor = sqLiteHelper.select();//是不是很简单?
                        查询出来的cursor一般会显示在listView中,这就要用到刚才提到的SimpleCursorAdapter
                                SimpleCursorAdapter adapter = new SimpleCursorAdapter(
                                                this,
                                                R.layout.list_row,
                                                cursor,
                                                new String[]{"tname","ttel"},
                                                new int[]{R.id.TextView01,R.id.TextView02}
                                        );

是不是很简单呢,任何复杂的工程都是通过简单的代码实现的.

快速上手Android数据库操作的更多相关文章

  1. 【第一篇】ASP.NET MVC快速入门之数据库操作(MVC5+EF6)

    目录 [第一篇]ASP.NET MVC快速入门之数据库操作(MVC5+EF6) [第二篇]ASP.NET MVC快速入门之数据注解(MVC5+EF6) [第三篇]ASP.NET MVC快速入门之安全策 ...

  2. [Android Pro] 完美Android Cursor使用例子(Android数据库操作)

    reference to : http://www.ablanxue.com/prone_10575_1.html 完美 Android Cursor使用例子(Android数据库操作),Androi ...

  3. android菜鸟学习笔记20----Android数据存储(四))Android数据库操作

    Android内置了一个名为SQLite的关系型数据库,这是一款轻量型的数据库,操作十分简便.SQLite与别的数据库不同的是,它没有数据类型.可以保存任何类型的数据到你所想要保存的任何表的任何列中. ...

  4. android数据库操作之直接读取db文件

    在对数据库操作时,常用的有两种方法: 1.在代码中建库.建表: 2.直接将相关库.表建立好,将db文件拷贝至assets目录下:     现在来看看第二种方法:   private String Ge ...

  5. android 数据库操作

    做android的数据库方面用的很少,所以用的时候记录下来,下次碰到直接copy,一下代码是最基本的实现: 首先是继承helper类: package com.create.rycreateim.db ...

  6. android 数据库操作详解

    请看郭大神的八篇专栏,包含sql语句  android封装的databasehelper 和郭大神自己的LitePal  三种使用详解 http://blog.csdn.net/column/deta ...

  7. WebAPI调用笔记 ASP.NET CORE 学习之自定义异常处理 MySQL数据库查询优化建议 .NET操作XML文件之泛型集合的序列化与反序列化 Asp.Net Core 轻松学-多线程之Task快速上手 Asp.Net Core 轻松学-多线程之Task(补充)

    WebAPI调用笔记   前言 即时通信项目中初次调用OA接口遇到了一些问题,因为本人从业后几乎一直做CS端项目,一个简单的WebAPI调用居然浪费了不少时间,特此记录. 接口描述 首先说明一下,基于 ...

  8. [ 转]Android快速开发–使用ORMLite操作数据库

    OrmLite是一个数据库操作辅助的开源框架,主要面向Java语言.在Android面向数据库开发中,是一个比较流行的开源框架,方便操作而且功能强大,今天来学习一下,最近的项目中也有所涉及,写个博客来 ...

  9. [译]:Xamarin.Android开发入门——Hello,Android Multiscreen快速上手

    原文链接:Hello, Android Multiscreen Quickstart. 译文链接:Hello,Android Multiscreen快速上手 本部分介绍利用Xamarin.Androi ...

随机推荐

  1. windows下顽固软件卸载不了的解决方法

    下面以autocad2012举例: cad2012卸载显示 “无法获得同类产品” 而且也安装不上. 解决方法:1,开始>运行>输入"regedit",找到下面的注册表路 ...

  2. Unity打包APK横屏时的注意事项

    由于你在Unity设置了横屏. 所以也需要在安卓的AndroidManifest.xml文件中, application/activity下声明为横屏.否则会黑屏,根本不给你报错,愁死你. 加上这一句 ...

  3. Android:控件的隐藏显示

    布局中的:android:visibility 程序中可用setVisibility(); 对应的三个常量值:0.4.8 VISIBLE:0 意思是可见的INVISIBILITY:4 意思是不可见的, ...

  4. Spring中的mappingResources和mappingDirectoryLocations

    今天使用Spring+Hibernate进行事务管理,按照顺序也就是配置,DataSource,Sessionfactory,事务管理器以及拦截器. DateSource可以直接使用Hibernate ...

  5. 如何用Maven创建一个普通Java项目

    一下内容包括:用Maven创建一个普通Java项目,并把该项目转成IDEA项目,导入到IDEA,最后把这个项目打包成一个jar文件. 有时候运行mvn命令失败,重复运行几次就OK了,无解(可能因为网络 ...

  6. java--面向接口编程

    之前看的一本书的笔记,上周再看设计模式的时候,想到了这篇之前在看某本书时候的笔记. 面向接口编程很重要的一点就是接口回调,用接口声明的变量称作接口变量,属于引用型变量,可以存放实现该接口的类的实例的引 ...

  7. noi2002银河英雄传说(并查集)

    首先表示对C++读入读出问题复杂程度的敬畏,看了好多没讲明白的,本题用cin竟然过不了评测,搞scanf的读入搞了好久.... 本题确实是一道经典的并查集题型,不多讲,拿来练练手用的(其中经历很惨) ...

  8. HDU 4746 (莫比乌斯反演) Mophues

    这道题看巨巨的题解看了好久,好久.. 本文转自hdu4746(莫比乌斯反演) 题意:给出n, m, p,求有多少对a, b满足gcd(a, b)的素因子个数<=p,(其中1<=a<= ...

  9. Java [Leetcode 110]Balanced Binary Tree

    题目描述: Given a binary tree, determine if it is height-balanced. For this problem, a height-balanced b ...

  10. poj 1392 Ouroboros Snake

    题目描述:咬尾蛇是古埃及神话中一种虚构的蛇.它经常把尾巴放在自己的嘴巴里,不停地吞噬自己.环数类似于咬尾蛇,它是2^n位的二进制数,具有如下性质:它能“生成”0-2^n-1之间的所有数.生成方法是:给 ...