Android4种存储方式介绍

INTEGER: 整数

REAL: 浮点数

TEXT: 字符串

BLOB: 大数据

它是一个轻量级的数据库、非常小 、 移植性好、效率高、可靠

在Android系统中提供了android.database.sqlite包,用于进行SQLite数据库的增、删、改、查工作。

创建与删除数据库

封装一个类去继承SQLiteOpenHelper  在构造函数中传入数据库名称与数据库版本号,数据库被创建的时候会调用onCreate(SQLiteDatabase db) 方法,数据库版本号发生改变的时候会调用onUpgrade(SQLiteDatabase db, int oldVersion, intnewVersion)方法,可以方便的对软件游戏升级后做出相应处理避免覆盖安装数据库发生改变产生的错误。调用SQLiteOpenHelper  的getReadableDatabase()方法去创建数据库,如果数据库不存在则创建并且返回SQLiteDatabase对象,如果数据库存在则不创建只返回SQLiteDatabase对象。调用 deleteDatabase(DATABASE_NAME)方法 传入数据库名称则可删除数据库。下面是个简单的例子,用来实现增删改:

  1. public class UserService {

  2. private DatabaseHelper helper;

  3. public UserService(Context context, String name, int version) {

  4. helper = new DatabaseHelper(context, name, version);

  5. }

  6. public UserService(Context context, String name) {

  7. helper = new DatabaseHelper(context, name);

  8. }

  9. public void insert(UserDao user) {// 插入数据

  10. SQLiteDatabase sdb = helper.getWritableDatabase();

  11. ContentValues values = new ContentValues();

  12. values.put(“username”, user.getUsername());

  13. values.put(“password”, user.getPassword());

  14. sdb.insert(“user”, “name”, values);

  15. sdb.close();

  16. }

  17. public void delete(int id) {// 删除数据

  18. SQLiteDatabase sdb = helper.getWritableDatabase();

  19. sdb.delete(“user”, “id=?”, new String[]{String.valueOf(id)});

  20. sdb.close();

  21. }

  22. public void update(UserDao user, int id) {// 更新数据

  23. SQLiteDatabase sdb = helper.getWritableDatabase();

  24. ContentValues values=new ContentValues();

  25. values.put(“username”, user.getUsername());

  26. values.put(“password”, user.getPassword());

  27. sdb.update(“user”, values, “id=?”, new String[]{String.valueOf(id)});

  28. sdb.close();

  29. }

  30. public Cursor select() {// 查询所有数据

  31. SQLiteDatabase sdb = helper.getWritableDatabase();

  32. return    sdb.query(“user”, new String[]{“id as _id”,“username”,“password”}, null, null, null, null, null);

  33. }

  34. public UserDao find(int id){//按id查询数据

  35. UserDao user=null;

  36. SQLiteDatabase sdb=helper.getWritableDatabase();

  37. Cursor cursor=sdb.query(“user”, new String[]{“id”,“username”,“password”}, “id=?”, new String[]{String.valueOf(id)}, null, null, null);

  38. if(cursor.moveToFirst()){

  39. user=new UserDao();

  40. user.setId(cursor.getInt(0));

  41. user.setUsername(cursor.getString(1));

  42. user.setPassword(cursor.getString(2));

  43. }

  44. cursor.close();

  45. sdb.close();

  46. return user;

  47. }

  48. }

插入数据:通过insert(String table, StringnullColumnHack, ContentValues values)方法插入数据,其中参数含义分别为:

table: 目标表名

nullColumnHack: 指定表中的某列列名。因为在SQLite中,不允许不允许插入所有列均为null的记录,因此初始值有值为空时,此列需显式赋予null

values:ContentValues对象,类似于java中的Map。以键值对的方式保存数据。

修改数据: update(String table,ContentValues values, String whereClause, String[] whereArgs)方法用于修改数据,其四个参数的具体含义如下:

table: 目标表名

values: 要被修改成为的新值

whereClause:where子句,除去where关键字剩下的部分,其中可带?占位符。如没有子句,则为null。

whereArgs: 用于替代whereClause参数中?占位符的参数。如不需传入参数,则为null。

查询数据:query()方法用SELECT 语句段构建查询。SELECT 语句内容作为 query() 方法的参数,比如:要查询的表名,要获取的字段名,WHERE 条件,包含可选的位置参数,去替代 WHERE 条件中位置参数的值,GROUP BY 条件,HAVING 条件。

除了表名,其他参数可以是 null。所以,以前的代码段可以可写成:

String[] columns={“ID”,“inventory”};

String[] parms={“snicklefritz”};

Cursor result=db.query(“widgets”,columns, “name=?”,parms, null, null, null);

使用游标

不管你如何执行查询,都会返回一个 Cursor,这是 Android 的 SQLite 数据库游标,使用游标,你可以:

通过使用 getCount() 方法得到结果集中有多少记录;

通过 moveToFirst(), moveToNext(), 和 isAfterLast() 方法遍历所有记录;

通过 getColumnNames() 得到字段名;

通过 getColumnIndex() 转换成字段号;

通过 getString(),getInt() 等方法得到给定字段当前记录的值;

通过 requery() 方法重新执行查询得到游标;

通过 close() 方法释放游标资源;

删除数据:删除数据也是一件很简单的事,只需要调用delete方法,传入参数即可,delete(String table, String whereClause,String[] whereArgs)的参数三个参数具体含义如下:

table: 目标表名

whereClause:where子句,除去where关键字剩下的部分,其中可带?占位符。如没有子句,则为null。

whereArgs: 用于替代whereClause参数中?占位符的参数。如不需传入参数,则为null。

4、**contentprovider:**contentprovider四种基本概念

1、  ContentProvider提供为存储和获取数据提供了统一的接口;

2、  使用ContentProvider可以在不同的应用程序之间共享数据

3、  Android为常见的一些数据提供了ContentPrivider(包括音频,视频,图片和通讯录等等)

ContentProvider使用表的形式来组织数据

Uri

1、  每一个ContentProvider都拥有一个公共的uri,这个uri用于表示这个ContentProvider所提供的数据

2、  Android所提供的ContentProvider都存放在android.provider包当中

Uri代表了要操作的数据,Uri主要包含了两部分信息:1.需要操作的ContentProvider ,对ContentProvider中的什么数据进行操作,一个Uri由以下几部分组成:

1.scheme:ContentProvider(内容提供者)的scheme已经由Android所规定为:content://。

2.主机名(或Authority):用于唯一标识这个ContentProvider,外部调用者可以根据这个标识来找到它。

3.路径(path):可以用来表示我们要操作的数据,路径的构建应根据业务而定,如下:

要操作contact表中id为10的记录,可以构建这样的路径:/contact/10

要操作contact表中id为10的记录的name字段, contact/10/name

要操作contact表中的所有记录,可以构建这样的路径:/contact

要操作的数据不一定来自数据库,也可以是文件等他存储方式,如下:

要操作xml文件中contact节点下的name节点,可以构建这样的路径:/contact/name

如果要把一个字符串转换成Uri,可以使用Uri类中的parse()方法,如下:

Uriuri =Uri.parse(“content://com.changcheng.provider.contactprovider/contact”)

ContentProvider所提供的函数:

1、  query():查询

2、  insert():插入

3、  update():更新

4、  delete():删除

5、  getType():得到数据类型

6、  onCreate():创建时的回调函数

实现ContentProvider的过程

1、  定义一个CONTENT_URI常量

2、  定义一个类,继承ContentProvider

3、  实现query,insert,update,delete,getType,onCreate方法

4、  在AndroidManifest.xml当中进行声明

下面是实现代码:

首先创建继承contentprovider的类UserContentProvider .java

  1. public class UserContentProvider extends ContentProvider {

  2. private DatabaseHelper helper;

  3. private SQLiteDatabase db;

  4. private static UriMatcher matcher = new UriMatcher(UriMatcher.NO_MATCH);

  5. private static final int USERS = 1;

  6. private static final int USER = 2;

  7. static{

  8. matcher.addURI(“cn.csdn.activity.providers.userprovider”, “user”, USERS);

  9. matcher.addURI(“cn.csdn.activity.providers.userprovider”, “user/#”, USER);

  10. }

  11. public int delete(Uri uri, String selection, String[]selectionArgs) {

  12. db=helper.getWritableDatabase();

  13. int num=0;

  14. switch(matcher.match(uri)){

  15. case USERS:

  16. num=db.delete(“user”, selection, selectionArgs);

  17. break;

  18. case USER:

  19. long id=ContentUris.parseId(uri);

  20. String where=“id=”+id;

  21. if(selection!=null&&!“”.equals(selection)){

  22. where=where+" and"+selection;

  23. }

  24. num=db.delete(“user”, where, selectionArgs);

  25. break;

  26. default:

  27. throw new IllegalArgumentException(“Unknown Uri:”+ uri);

  28. }

  29. return num;

  30. }

  31. public String getType(Uri uri) {

  32. switch(matcher.match(uri)){

  33. case USERS:

  34. return “vnd.android.cursor.dir/person”;

  35. case USER:

  36. return “vnd.android.cursor.item/person”;

  37. default:

  38. throw new IllegalArgumentException(“Unknown Uri:”+ uri);

  39. }

  40. }

  41. public Uri insert(Uri uri, ContentValues values) {

  42. db=helper.getWritableDatabase();

  43. long rowid;

  44. switch(matcher.match(uri)){

  45. case USERS: //向表中添加新纪录并返回其行号

  46. rowid=db.insert(“user”, “id”, values);

  47. return ContentUris.withAppendedId(uri, rowid);

  48. default:

  49. throw new IllegalArgumentException(“Unknow Uri:” + uri);

  50. }

  51. }

  52. public boolean onCreate() {

  53. helper=new DatabaseHelper(this.getContext(),“users.db”);

  54. return true;

  55. }

  56. public Cursor query(Uri uri, String[] projection, Stringselection,

  57. String[] selectionArgs, String sortOrder) {

  58. db = helper.getReadableDatabase();

  59. switch(matcher.match(uri)){

  60. case USERS:

  61. return db.query(“user”, projection, selection, selectionArgs, null, null, sortOrder);

  62. case USER:

  63. long id=ContentUris.parseId(uri);

  64. String where=“id=”+id;

  65. if(selection!=null&&!“”.equals(selection)){

  66. where=where+" and"+selection;

  67. }

  68. return db.query(“user”, projection, where, selectionArgs, null, null, sortOrder);

  69. default:

  70. throw new IllegalArgumentException(“Unknown Uri:”+ uri);

  71. }

  72. }

  73. public int update(Uri uri, ContentValues values, String selection,

  74. String[] selectionArgs) {

  75. db=helper.getWritableDatabase();

  76. int num;

  77. switch(matcher.match(uri)){

  78. case USERS:

  79. num=db.update(“user”, values, selection, selectionArgs);

  80. break;

  81. case USER:

  82. long id=ContentUris.parseId(uri);

  83. String where=“id=”+id;

  84. if(selection!=null&&!“”.equals(selection)){

  85. where=where+" and"+selection;

  86. }

  87. num=db.update(“user”, values, selection, selectionArgs);

  88. break;

  89. default:

  90. throw new IllegalArgumentException(“Unknow Uri”+uri);

  91. }

  92. return num;

  93. }

  94. }

  95. 配置manifest.xml:

  96. 需要在中为provider进行注册!!!!

  97. provider android:authorities=“cn.csdn.activity.providers.userprovider”

  98. android:name=“UserContentProvider”>

  99. 最后写测试类:

  100. //contentprovider测试

  101. public void testinsert(){//插入数据

  102. ContentResolver resolver = this.getContext().getContentResolver();

  103. Uri inserturi=Uri.parse(“content://cn.csdn.activity.providers.userprovider/user”);

  104. ContentValuesvalues=new ContentValues();

  105. values.put(“username”, “renhiali”);

  106. values.put(“password”, “123”);

  107. Uri uri=resolver.insert(inserturi, values);

Android开发除了flutter还有什么是必须掌握的吗?

相信大多数从事Android开发的朋友们越来越发现,找工作越来越难了,面试的要求越来越高了

除了基础扎实的java知识,数据结构算法,设计模式还要求会底层源码,NDK技术,性能调优,还有会些小程序和跨平台,比如说flutter,以思维脑图的方式展示在下图;

参考docs.qq.com/doc/DSkNLaERkbnFoS0ZF
r = this.getContext().getContentResolver();

  1. Uri inserturi=Uri.parse(“content://cn.csdn.activity.providers.userprovider/user”);

  2. ContentValuesvalues=new ContentValues();

  3. values.put(“username”, “renhiali”);

  4. values.put(“password”, “123”);

  5. Uri uri=resolver.insert(inserturi, values);

Android开发除了flutter还有什么是必须掌握的吗?

相信大多数从事Android开发的朋友们越来越发现,找工作越来越难了,面试的要求越来越高了

除了基础扎实的java知识,数据结构算法,设计模式还要求会底层源码,NDK技术,性能调优,还有会些小程序和跨平台,比如说flutter,以思维脑图的方式展示在下图;

[外链图片转存中…(img-G1pdrBr6-1724473173327)]

参考docs.qq.com/doc/DSkNLaERkbnFoS0ZF

  • 18
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值