Geekband第六章

来源:互联网 发布:游戏秀 录制软件 编辑:程序博客网 时间:2024/06/06 03:12

本章内容是SQLite和ContentProvider,都是比较重要的知识。
一、SQLite
SQL 语句的空格一定要留意,稍不留神就会出错。
数据库的后缀 .db

1、创建,建类,继承SQLiteOpenHelper

public class DatabaseHelper extends SQLiteOpenHelper {public static final String DATABASE_NAME = "test.db";    public static final String TABLE_NAME = "user";    public static final String USERNAME = "username";    public static final String PASSWORD = "password ";/**     * 构造方法的后三个参数设为super的三个固定值     * @param context  context     * @param name    数据库的名字     * @param factory null     * @param version 版本可为0或1     */public DatabaseHelper(Context context) {super(context, DATABASE_NAME, null, 1);Log.i("xyy","DatabaseHelper");}//    创建一个表  user 表名 列名@Overridepublic void onCreate(SQLiteDatabase db) {        db.execSQL("create table " + TABLE_NAME + "(" + USERNAME + " varchar(20) not null," +" " + PASSWORD + "varchar(60) not null);");Log.i("xyy","onCreate");}@Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {        Log.i("xyy","onUpgrade");}}

2、使用,创建 MainActivity

DatabaseHelper databaseHelper=new DatabaseHelper(this);SQLiteDatabase sqLiteDatabase=databaseHelper.getWritableDatabase();

3、 增———- ,点击按钮,添加一条数据,一个ContentValues是一条数据,类似于HashMap,用键值对的方式

findViewById(R.id.add).setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {        ContentValues contentValues=new ContentValues();        contentValues.put(DatabaseHelper.USERNAME,"极客班");        contentValues.put(DatabaseHelper.PASSWORD,"diflese");         longrowNumber=mSqLiteDatabase.insert(DatabaseHelper.TABLE_NAME,                                        null,contentValues);         if(rowNumber!=-1){Toast.makeText(MainActivity.this,                             "插入成功",Toast.LENGTH_SHORT).show();}    }});

4.删

//        删除数据findViewById(R.id.delete).setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {//       删除是那列String whereClauseString="username=?";//       删除是那行String[] whereArgsString={"极客班"};mSqLiteDatabase.delete(DatabaseHelper.TABLE_NAME,whereClauseString,whereArgsString);}});

5.改

//        更新数据ContentValues contentValues=new ContentValues();contentValues.put(DatabaseHelper.AGE,"100");//        更新那列String whereClauseString="username=?";//        更新哪行String[] whereArgsString={"极客班"};mSqLiteDatabase.update(DatabaseHelper.TABLE_NAME,contentValues,whereClauseString,whereArgsString);

6.查

//        查找数据/** * 参数1,表名  参数2,列名(想要的)   参数3,条件字句 * 参数4,条件语句的参数数组, 参数5,分组  参数6,分组条件 * 参数7,按什么条件排序  参数8,分页查询的限制 */Cursor cursor=mSqLiteDatabase.query(DatabaseHelper.TABLE_NAME,        null,null,null,null,null,null);if(cursor.moveToFirst()){int count = cursor.getCount();    for (int i = 0; i < count; i++) {        String userName=cursor.getString(cursor.getColumnIndexOrThrow(DatabaseHelper.USERNAME));Log.i("xyy",userName+""+i);}}

7.事务

//        当数据量很大时。使用事务//        开始事务,此时数据库会被锁定。mSqLiteDatabase.beginTransaction(); try{//       做你的操作 添加等。循环插入一千条数据    mSqLiteDatabase.setTransactionSuccessful();}catch (Exception e){     e.printStackTrace();}finally {//      结束事务。提交    mSqLiteDatabase.endTransaction();}

总结:
SQLite使用C语言编写的开源嵌入式数据库引擎。它支持大多数SQL92标准,可以在所有主要的操作系统上运行。
*支持高达2TB大小的数据库
*以单个文件的形式存在
*以B-Tree的数据结构形式存储在磁盘
特点:
1.轻量级,一个动态库,单文件
2.独立性 没有依赖,无序安装
3.隔离性 全部在一个文件夹
4.跨平台 支持众多操作系统
5.多语言接口 支持众多编程语言
6.安全性 事务
通过数据库上的独占性和共享锁来实现独立事务处理
多个进程可以在同一时间从同一数据库读取数据,但只有一个可以写入数据
数据类型:NULL INTEGER ,REAL ,TEXT 和BLOB。就是空值,整型,浮点型,字符串和二进制对象

常用方法:
getCount() 总记录条数
isFisrt() 判断是否第一条记录
isLast() 判断是否最后一条记录
moveToFirst() 移动到第一条记录
moveToLast() 移动到最后一条记录
move(int offset) 移动到指定记录
moveToNext() 移动到下一条记录
moveToPrevious() 移动到上一条记录
getColumnIndexOrThrow(String columnName) 据列名称获得列索引
getInt(int columnIndex) 获得指定列索引的int类型值
getString(int columnIndex) 获得指定列索引的String类型值

二、ContentProvider
ContentProvider向我们提供了我们在应用程序之前共享数据的一种机制.

1)、ContentProvider为存储和获取数据提供了统一的接口。ContentProvide对数据进行封装,不用关心数据存储的细节。使用表的形式来组织数据。
2)、使用ContentProvider可以在不同的应用程序之间共享数据。
3)、Android为常见的一些数据提供了默认的ContentProvider(包括音频、视频、图片和通讯录等)。

Uri介绍

content://com.bing.provider.myprovider/tablename/#

A:标准前缀,用来说明一个Content Provider控制这些数据,无法改变的;”content://”
B:URI 的标识,用于唯一标识这个ContentProvider,外部调用者可以根据这个标识来找到它。它定义了是哪个Content Provider提供这些数据。对于第三方应用程序,为了保证URI标识的唯一性,它必须是一个完整的、小写的类名。这个标识在 元素的 authorities属性中说明:一般是定义该ContentProvider的包.类的名称
C:路径(path),通俗的讲就是你要操作的数据库中表的名字,或者你也可以自己定义,记得在使用的时候保持一致就可以了;”content://com.bing.provider.myprovider/tablename”
D:如果URI中包含表示需要获取的记录的ID;则就返回该id对应的数据,如果没有ID,就表示返回全部; “content://com.bing.provider.myprovider/tablename/#” #表示数据id。

UriMatcher类介绍
因为Uri代表了要操作的数据,所以我们经常需要解析Uri,并从Uri中获取数据。Android系统提供了用于操作Uri的工具类,UriMatcher。

//常量UriMatcher.NO_MATCH表示不匹配任何路径的返回码UriMatcher  sMatcher = new UriMatcher(UriMatcher.NO_MATCH);//如果match()方法匹配content://com.bing.procvide.personprovider/person路径,返回匹配码为1sMatcher.addURI("com.bing.procvide.personprovider", "person", 1);//添加需要匹配uri,如果匹配就会返回匹配码//如果match()方法匹配content://com.bing.provider.personprovider/person/230路径,返回匹配码为2sMatcher.addURI("com.bing.provider.personprovider", "person/#", 2);//#号为通配符switch (sMatcher.match(Uri.parse("content://com.ljq.provider.personprovider/person/10"))) {    case 1     break;   case 2     break;   default://不匹配     break;}

内容提供者将一些特定的应用程序数据提供给其他应用程序使用。
数据可以存储于文件系统,SQLite数据库或其他方式
内容提供者继承于ContentProvider基类,为其他程序取用和存储它管理的数据实现了一套标准方法
应用程序并不直接调用这些方法,而是ContentResolver对象,调用它的方法替代。
ContentResolver可以与任意内容提供者进行会话,与其合作来对所有相关交互通讯进行管理。

ContentProvider 内容提供器,是自己程序做的类。
ContentResolver 内容解析器,是别的程序用的类。

ContentProvider共享数据
1)ContentProvider类主要方法的作用:
public boolean onCreate():该方法在ContentProvider创建后就会被调用,Android开机后,ContentProvider在其它应用第一次访问它时才会被创建。
public Uri insert(Uri uri, ContentValues values):该方法用于供外部应用往ContentProvider添加数据。
public int delete(Uri uri, String selection, String[] selectionArgs):该方法用于供外部应用从ContentProvider删除数据。
public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs):该方法用于供外部应用更新ContentProvider中的数据。
public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder):该方法用于供外部应用从ContentProvider中获取数据。
public String getType(Uri uri):该方法用于返回当前Url所代表数据的MIME类型。

ContentResolver操作ContentProvider中的数据

1)当外部应用需要对ContentProvider中的数据进行添加、删除、修改和查询操作时,可以使用ContentResolver 类来完成,要获取ContentResolver 对象,可以使用Activity提供的getContentResolver()方法。

2)ContentResolver 类提供了与ContentProvider类相同签名的四个方法:
public Uri insert(Uri uri, ContentValues values):该方法用于往ContentProvider添加数据。
public int delete(Uri uri, String selection, String[] selectionArgs):该方法用于从ContentProvider删除数据。
public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs):该方法用于更新ContentProvider中的数据。
public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder):该方法用于从ContentProvider中获取数据。

这些方法的第一个参数为Uri,代表要操作的ContentProvider和对其中的什么数据进行操作,
其实和contentprovider里面的方法是一样的.他们所对应的数据,最终是会被传到我们在之前程序里面定义的那个contentprovider类的方法,

ContentProvider的实现过程
Database
Uri
UriMacther
ContentProvider
query/insert/delete/update
AndroidManifest.xml

0 0