安卓需要存一些参数信息、测量数据和计算结果,File和SQlite哪个好

安卓需要存一些参数信息、测量数据和计算结果,File和SQlite哪个好,第1张

使用SQLite方式存储数据

在Android中一共提供了5种数据存储方式,分别为:

(1)Files:通过FileInputStream和FileOutputStream对文件进行 *** 作。具体使用方法可以参阅博文《Android学习笔记34:使用文件存储数据》。

(2)Shared Preferences:常用来存储键值对形式的数据,对系统配置信息进行保存。具体使用方法可以参阅博文《Android学习笔记35:使用Shared Preferences方式存储数据》。

(3)Content Providers:数据共享,用于应用程序之间数据的访问。

(4)SQLite:Android自带的轻量级关系型数据库,支持SQL语言,用来存储大量的数据,并且能够对数据进行使用、更新、维护等 *** 作。

(5)Network:通过网络来存储和获取数据。

本篇博文介绍第四种方式,通过Android自带的SQLite数据库存储数据。

1SQLite简介

SQLite是一款开源的、嵌入式关系型数据库,第一个版本Alpha发布于2000年。SQLite在便携性、易用性、紧凑性、高效性和可靠性方面有着突出的表现。

SQLite和C/S模式的数据库软件不同,它是一款嵌入式数据库,没有独立运行的进程,与所服务的应用程序在应用程序进程空间内共生共存。它的代码与应用程序代码也是在一起的,或者说嵌入其中,作为托管它的程序的一部分。因此不存在数据库的客户端和服务器,使用SQLite一般只需要带上它的一个动态库,就可以享受它的全部功能。

数据库服务器在程序中的好处是不需要网络配置或管理。将数据库客户端与服务器运行在同一个进程中,可以省去不少的 *** 作及麻烦:不用担心防火墙或者地址解析;不用浪费时间管理复杂的授权和权限;可以减少网络调用相关的消耗;可以简化数据库管理并使程序更容易部署。

SQLite数据库通过数据库级上的独占性和共享锁来实现独立事务处理。这意味着多个进程可以在同一时间从同一数据库读取数据,但是只有一个可以写入数据。在某个进程向数据库执行写 *** 作之前,必须获得独占锁定。在发出独占锁定后,其他的读写 *** 作将不会再发生。

此外,SQLite数据库中的所有信息(比如表、视图、触发器等)都包含在一个文件内,方便管理和维护。SQLite数据库还支持大部分 *** 作系统,除电脑上使用的 *** 作系统之外,很多手机上使用的 *** 作系统同样可以运行。同时,SQLite数据库还提供了多语言的编程接口,供开发者使用。

2SQL基本命令

SQL是与关系型数据库通信的唯一方式。它专注于信息处理,是为构建、读取、写入、排序、过滤、映射、分组、聚集和通常的管理信息而设计的声明式语言。

在讲解SQL基本命令之前,有必要先了解一下SQLite所支持的数据类型都有哪些。

21 SQLite支持的数据类型

SQLite采用动态数据存储类型,会根据存入的值自动进行判断。SQLite支持以下5种数据类型:

(1)NULL:空值

(2)INTEGER:带符号的整型

(3)REAL:浮点型

(4)TEXT:字符串文本

(5)BLOB:二进制对象

22 SQL基本命令

表是探索SQLite中SQL的起点,也是关系型数据库中信息的标准单位,所有的 *** 作都是以表为中心的。那么如何使用SQL命令创建一张表呢?

221创建表

表是由行和列组成的,列称为字段,行称为记录。

使用CREATE命令可以创建表,CREATE命令的一般格式为:

CREATE [TEMP/TEMPORARY] TABLE table_name (column_definitions [, constraints]);

其中,[]中的内容是可选的,用TEMP或TEMPORARY关键字声明的表是临时表,这种表只存活于当前会话,一旦连接断开,就会被自动销毁。如果没有明确指出创建的表是临时表,则创建的是基本表,将会在数据库中持久存在,这也是数据库中最常见的表。

CREATE TABLE命令至少需要一个表名和一个字段名,上述命令中的table_name表示表名,表名必须与其他标识符不同。column_definitions由用逗号分隔的字段列表组成,每个字段定义包括一个名称、一个域(类型)和一个逗号分隔的字段约束。其中,域是指存储在该列的信息的类型,约束用来控制什么样的值可以存储在表中或特定的字段中。

一条创建表的命令示例如下:

1 CREATE TABLE tab_student (studentId INTEGER PRIMARY KEY AUTOINCREMENT,

2 studentName VARCHAR(20),

3 studentAge INTEGER);

如上,我们创建了一个名为tab_student的表,该表包含3个字段:studentId、 studentName和studentAge,其数据类型分别为:INTEGER、VARCHAR和INTEGER。

此外,通过使用关键字PRIMARY KEY,我们指定了字段studentId所在的列是主键。主键确保了每一行记录在某种方式上与表中的其他行记录是不同的(唯一的),进而确保了表中的所有字段都是可寻址的。

SQLite为主键提供自增长功能,当定义字段类型为INTEGER PRIMARY KEY时,SQLite将为该字段创建默认值,该默认值确保整数值是唯一的。SQLite使用64-bit单符号整数主键,因此,该字段的最大值是9,223,372,036,854,775,807。当达到最大值时,SQLite会自动搜索该字段还未使用的值,并作为要插入的值。从表中删除记录时,rowid可能被回收并在后面的插入中使用。因此,新创建的rowid不一定是按照严格顺序增长的。如果想要SQLite使用唯一的自动主键值,而不是填补空白,可以在主键定义INTEGER PRIMARY KEY中加入关键字AUTOINCREMENT。AUTOINCREMENT关键字阻止rowid回收,它将为新插入的记录产生新的(不是回收的)rowid。

222插入记录

使用INSERT命令可以一次插入一条记录,INSERT命令的一般格式为:

INSERT INTO tab_name (column_list) VALUES (value_list);

其中,tab_name指明将数据插入到哪个表中,column_list是用逗号分隔的字段名称,这些字段必须是表中存在的,value_list是用逗号分隔的值列表,这些值是与column_list中的字段一一对应的。

比如,向刚才创建的tab_student表中插入一条记录,便可以使用如下的语句完成:

INSERT INTO tab_student (studentId, studentName, studentAge) VALUES (1, “jack”, 23);

通过以上的语句,便插入了一条studentName=”jack”, studentAge=”23”的记录,该记录的主键为studentId=1。

223更新记录

使用UPDATE命令可以更新表中的记录,该命令可以修改一个表中一行或者多行中的一个或多个字段。UPDATE命令的一般格式为:

UPDATE tab_name SET update_list WHERE predicate;

其中,update_list是一个或多个字段赋值的列表,字段赋值的格式为column_name=value。WHERE子句使用断言识别要修改的行,然后将更新列应用到这些行。

比如,要更新刚才插入到tab_student表中的记录,便可以使用如下的语句完成:

UPDATE tab_student SET studentName=”tom”, studentAge=”25” WHERE studentId=1;

通过以上的语句,便可以将刚才插入的主键为studentId=1的记录更新为studentName=”tom”, studentAge=”25”了。

224删除记录

使用DELETE命令可以删除表中的记录,DELETE命令的一般格式为:

DELETE FROM table_name WHERE predicate;

其中,table_name指明所要删除的记录位于哪个表中。和UPDATE命令一样,WHERE子句使用断言识别要删除的行。

比如,要删除刚才插入的记录,便可以使用如下的语句完成:

DELETE FROM tab_student WHERE studentId=1;

225查询记录

SELECT命令是查询数据库的唯一命令。SELECT命令也是SQL命令中最大、最复杂的命令。

SELECT命令的通用形式如下:

SELECT [distinct] heading

FROM tables

WHERE predicate

GROUP BY columns

HAVING predicate

ORDER BY columns

LIMIT count,offset;

其中,每个关键字(如FROM、WHERE、HAVING等)都是一个单独的子句,每个子句由关键字和跟随的参数构成。GROUP BY和HAVING一起工作可以对GROUP BY进行约束。ORDER BY使记录集在返回之前按一个或多个字段的值进行排序,可以指定排序方式为ASC(默认的升序)或DESC(降序)。此外,还可以使用LIMIT限定结果集的大小和范围,count指定返回记录的最大数量,offset指定偏移的记录数。

在上述的SELECT命令通用形式中,除了SELECT之外,所有的子句都是可选的。目前最常用的SELECT命令由三个子句组成:SELECT、FROM、WHERE,其基本语法形式如下:

SELECT heading FROM tables WHERE predicate;

比如,要查询刚才插入的记录,便可以使用如下的语句完成:

SELECT studentId, studentName, studentAge FROM tab_student WHERE studentId=1;

至此,我们介绍了SQL中最基本和最常用的CREATE、INSERT、UPDATE、DELETE和SELECT命令。当然了,这里只是对其进行了简单的介绍,有关SQLite中SQL命令的详细使用方法,可以参阅《SQLite权威指南》一书的第三章和第四章。

3数据库 *** 作辅助类SQLiteOpenHelper

Android提供了一个重要的类SQLiteOpenHelper,用于辅助用户对SQLite数据库进行 *** 作。

SQLiteOpenHelper的构造函数原型如下:

public SQLiteOpenHelper(Context context, String name, SQLiteDatabaseCursorFactory factory, int version);

其中,参数context表示应用程序运行的环境,包含应用程序所需的共享资源。参数name表示Android的数据库名字。参数factory是SQLiteDatabaseCursorFactory类对象,用于存储查询Android SQLite数据库的结果集。参数version表示应用程序所用的数据库的版本,该版本并非SQLite的真正版本,而是指定应用程序中的SQLite数据库的版本,当该版本号发生变化时,将会触发SQLiteOpenHelper类中的onUpgrade()或onDowngrade()方法。

SQLiteOpenHelper类的所有方法如图1所示。

图1 SQLiteOpenHelper类的方法

其中,close()方法用于关闭SQLiteOpenHelper对象中的SQLite数据库;getReadableDatabase()方法和getWriteableDatabase()方法类似,getReadableDatabase()方法以只读状态打开SQLiteOpenHelper对象中指定的SQLite数据库,任何想要修改数据库的 *** 作都是不允许的;getWriteableDatabase()方法也是打开数据库,但是允许数据库正常的读/写 *** 作;在一个不存在的数据库上调用任何方法时,都会隐式的调用SQLiteOpenHelper对象的onCreate()方法;当应用程序第一次访问数据库时,则会调用onOpen()方法,但是,如果版本号发生了变化的话,则会调用onUpgrade()或onDowngrade()方法。

4数据库类SQLiteDatabase

SQLiteDatabase类用来完成对数据库的 *** 作任务,比如表的选择、插入、更新和删除语句等。

SQLiteDatabase类中常用的用于执行SQL语句的方法有以下一些。

(1)execSQL()方法:

public void execSQL (String sql);

public void execSQL (String sql, Object[] bindArgs);

(2)query()方法:

public Cursor query (String table, String[] columns, String selection, String[] selectionArgs, String

groupBy, String having,String orderBy, String limit);

public Cursor query (boolean distinct, String table, String[] columns, String selection, String[] selectionArgs, String

groupBy, String having, String orderBy, String limit, CancellationSignal cancellationSignal);

public Cursor query (String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String

having,String orderBy);

public Cursor query (boolean distinct, String table, String[] columns, String selection, String[] selectionArgs, String

groupBy, String having, String orderBy, String limit);

(3)queryWithFactory()方法:

public Cursor queryWithFactory (SQLiteDatabaseCursorFactory cursorFactory, boolean distinct, String table, String[]columns, String selection, String[] selectionArgs, String groupBy, String having, String

orderBy, String limit,CancellationSignal cancellationSignal);

public Cursor queryWithFactory (SQLiteDatabaseCursorFactory cursorFactory, boolean distinct, String table, String[]columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy, String limit);

(4)rawQuery()方法:

public Cursor rawQuery (String sql, String[] selectionArgs, CancellationSignal cancellationSignal);

public Cursor rawQuery (String sql, String[] selectionArgs);

(5)rawQueryWithFactory()方法:

public Cursor rawQueryWithFactory (SQLiteDatabaseCursorFactory cursorFactory, String sql, String[]

selectionArgs,String editTable);

public Cursor rawQueryWithFactory (SQLiteDatabaseCursorFactory cursorFactory, String sql, String[]

selectionArgs,String editTable, CancellationSignal cancellationSignal);

其中,execSQL()方法都有一个参数sql,这个参数是一个SQL语句。第二个参数bindArgs接收一个数组,数组中的每个成员捆绑了一个查询。execSQL()方法用于运行那些没有返回值的查询语句,比如创建、插入、更新和修改表。

query()方法和queryWithFactory()方法是在数据库中运行一些轻量级的单查询语句,参数包括table、columns、groupBy、having、orderBy、limit等SQL语句关键字。这些方法允许将SQL语句传递给相关方法,而不必直接使用SQL语句。

rawQuery()方法和rawQueryWithFactory()方法也都有一个参数sql,用于执行SQL查询语句,返回值是Cursor对象。这两个方法都有一个版本能够接收一个字符串数组selectionArgs作为参数,通过这个参数,SQLiteDatabase对象将把捆绑的SQL语句中的问号(?)用这个数组中的值代替,并按照一一对应的位置关系进行取代。

SQLiteDatabase类提供了大约50个方法,除此之外还有一些用于打开数据库的方法(如openDatabase()、openOrCreateDatabase()等),用于管理SQLite事务的方法(如beginTransaction()、endTransaction()等),用于测试数据库是否被锁住的方法(如isDbLockedByCurrentThread()、isDbLockedByOtherThread()等),以及获取数据库基本信息的方法(如getMaximumSiza()、getVersion()等)。这里就不一一介绍了,具体可以参阅SQLiteDatabase类的API帮助文档。

5游标类Cursor

在Android中,查询数据是通过Cursor类来实现的,当我们使用SQLiteDatabasequery()或SQLiteDatabaserawQuery()方法时,会得到一个Cursor对象,Cursor指向的就是每一条记录,它提供了很多有关查询的方法,如图2所示。

>

第一种: 使用SharedPreferences存储数据

适用范围:保存少量的数据,且这些数据的格式非常简单:字符串型、基本类型的值。比如应用程序的各种配置信息(如是否打开音效、是否使用震动效果、小游戏的玩家积分等),解锁口 令密码等

核心原理:保存基于XML文件存储的key-value键值对数据,通常用来存储一些简单的配置信息。通过DDMS的File Explorer面板,展开文件浏览树,很明显SharedPreferences数据总是存储在/data/data/<package name>/shared_prefs目录下。SharedPreferences对象本身只能获取数据而不支持存储和修改,存储修改是通过SharedPreferencesedit()获取的内部接口Editor对象实现。 SharedPreferences本身是一 个接口,程序无法直接创建SharedPreferences实例,只能通过Context提供的getSharedPreferences(String name, int mode)方法来获取SharedPreferences实例,该方法中name表示要 *** 作的xml文件名,第二个参数具体如下:

ContextMODE_PRIVATE: 指定该SharedPreferences数据只能被本应用程序读、写。

ContextMODE_WORLD_READABLE:  指定该SharedPreferences数据能被其他应用程序读,但不能写。

ContextMODE_WORLD_WRITEABLE:  指定该SharedPreferences数据能被其他应用程序读,写

Editor有如下主要重要方法:

SharedPreferencesEditor clear():清空SharedPreferences里所有数据

SharedPreferencesEditor putXxx(String key , xxx value): 向SharedPreferences存入指定key对应的数据,其中xxx 可以是boolean,float,int等各种基本类型据

SharedPreferencesEditor remove(): 删除SharedPreferences中指定key对应的数据项

boolean commit(): 当Editor编辑完成后,使用该方法提交修改

实际案例:运行界面如下

这里只提供了两个按钮和一个输入文本框,布局简单,故在此不给出界面布局文件了,程序核心代码如下:

读写其他应用的SharedPreferences: 步骤如下

1、在创建SharedPreferences时,指定MODE_WORLD_READABLE模式,表明该SharedPreferences数据可以被其他程序读取

2、创建其他应用程序对应的Context:

Context pvCount = createPackageContext("comtonyapp", ContextCONTEXT_IGNORE_SECURITY);这里的comtonyapp就是其他程序的包名

3、使用其他程序的Context获取对应的SharedPreferences

SharedPreferences read = pvCountgetSharedPreferences("lock", ContextMODE_WORLD_READABLE);

4、如果是写入数据,使用Editor接口即可,所有其他 *** 作均和前面一致。

SharedPreferences对象与SQLite数据库相比,免去了创建数据库,创建表,写SQL语句等诸多 *** 作,相对而言更加方便,简洁。但是SharedPreferences也有其自身缺陷,比如其职能存储boolean,int,float,long和String五种简单的数据类型,比如其无法进行条件查询等。所以不论SharedPreferences的数据存储 *** 作是如何简单,它也只能是存储方式的一种补充,而无法完全替代如SQLite数据库这样的其他数据存储方式。

第二种: 文件存储数据

核心原理: Context提供了两个方法来打开数据文件里的文件IO流 FileInputStream openFileInput(String name); FileOutputStream(String name , int mode),这两个方法第一个参数 用于指定文件名,第二个参数指定打开文件的模式。具体有以下值可选:

MODE_PRIVATE:为默认 *** 作模式,代表该文件是私有数据,只能被应用本身访问,在该模式下,写入的内容会覆盖原文件的内容,如果想把新写入的内容追加到原文件中。可   以使用ContextMODE_APPEND

MODE_APPEND:模式会检查文件是否存在,存在就往文件追加内容,否则就创建新文件。

MODE_WORLD_READABLE:表示当前文件可以被其他应用读取;

MODE_WORLD_WRITEABLE:表示当前文件可以被其他应用写入。

除此之外,Context还提供了如下几个重要的方法:

getDir(String name , int mode):在应用程序的数据文件夹下获取或者创建name对应的子目录

File getFilesDir():获取该应用程序的数据文件夹得绝对路径

String[] fileList():返回该应用数据文件夹的全部文件             

实际案例:界面沿用上图

核心代码如下:

openFileOutput()方法的第一参数用于指定文件名称,不能包含路径分隔符“/” ,如果文件不存在,Android 会自动创建它。创建的文件保存在/data/data/<package name>/files目录,如: /data/data/cntonyapp/files/messagetxt,

下面讲解某些特殊文件读写需要注意的地方:

读写sdcard上的文件

其中读写步骤按如下进行:

1、调用Environment的getExternalStorageState()方法判断手机上是否插了sd卡,且应用程序具有读写SD卡的权限,如下代码将返回true

EnvironmentgetExternalStorageState()equals(EnvironmentMEDIA_MOUNTED)

2、调用EnvironmentgetExternalStorageDirectory()方法来获取外部存储器,也就是SD卡的目录,或者使用"/mnt/sdcard/"目录

3、使用IO流 *** 作SD卡上的文件

注意点:手机应该已插入SD卡,对于模拟器而言,可通过mksdcard命令来创建虚拟存储卡

必须在AndroidManifestxml上配置读写SD卡的权限

<uses-permission android:name="androidpermissionMOUNT_UNMOUNT_FILESYSTEMS"/>

<uses-permission android:name="androidpermissionWRITE_EXTERNAL_STORAGE"/>

案例代码:

第三种:SQLite存储数据

SQLite是轻量级嵌入式数据库引擎,它支持 SQL 语言,并且只利用很少的内存就有很好的性能。现在的主流移动设备像Android、iPhone等都使用SQLite作为复杂数据的存储引擎,在我们为移动设备开发应用程序时,也许就要使用到SQLite来存储我们大量的数据,所以我们就需要掌握移动设备上的SQLite开发技巧

SQLiteDatabase类为我们提供了很多种方法,上面的代码中基本上囊括了大部分的数据库 *** 作;对于添加、更新和删除来说,我们都可以使用

以上三个方法的第一个参数都是表示要 *** 作的表名;insert中的第二个参数表示如果插入的数据每一列都为空的话,需要指定此行中某一列的名称,系统将此列设置为NULL,不至于出现错误;insert中的第三个参数是ContentValues类型的变量,是键值对组成的Map,key代表列名,value代表该列要插入的值;update的第二个参数也很类似,只不过它是更新该字段key为最新的value值,第三个参数whereClause表示WHERE表达式,比如“age > and age < ”等,最后的whereArgs参数是占位符的实际参数值;delete方法的参数也是一样

下面给出demo

数据的添加

1使用insert方法

在上面的代码示例中,已经用到了这几个常用方法中的一些,关于更多的信息,大家可以参考官方文档中的说明。

最后当我们完成了对数据库的 *** 作后,记得调用SQLiteDatabase的close()方法释放数据库连接,否则容易出现SQLiteException。

上面就是SQLite的基本应用,但在实际开发中,为了能够更好的管理和维护数据库,我们会封装一个继承自SQLiteOpenHelper类的数据库 *** 作类,然后以这个类为基础,再封装我们的业务逻辑方法。

这里直接使用案例讲解:下面是案例demo的界面

Android sqlite3数据库管理工具

Android SDK的tools目录下提供了一个sqlite3exe工具,这是一个简单的sqlite数据库管理工具。开发者可以方便的使用其对sqlite数据库进行命令行的 *** 作。

程序运行生成的db文件一般位于"/data/data/项目名(包括所处包名)/databases/db",因此要对数据库文件进行 *** 作需要先找到数据库文件:

1、进入shell 命令

adb shell

2、找到数据库文件

#cd data/data

#ls                --列出所有项目

#cd project_name   --进入所需项目名

#cd databases    

#ls                --列出现寸的数据库文件

3、进入数据库

#sqlite3 test_db   --进入所需数据库

会出现类似如下字样:

SQLite version 3622

Enter "help" for instructions

Enter SQL statements terminated with a ";"

sqlite>

至此,可对数据库进行sql *** 作。

4、sqlite常用命令

>databases        --产看当前数据库

>tables           --查看当前数据库中的表

>help             --sqlite3帮助

>schema            --各个表的生成语句

以上便是android开发存储数据的五种方法!

是一个免费的开源的、简易的、遵循Apache2开源协议发布的Android开发框架,其开发宗旨是简单、快速的进行Android应用程序的开发,包含Androidmvc、简易sqliteorm、ioc模块、封装Android>

目前主要有以下模块:

MVC模块:实现视图与模型的分离。

ioc模块:android中的ioc模块,完全注解方式就可以进行UI绑定、res中的资源的读取、以及对象的初始化。

数据库模块:android中的orm框架,使用了线程池对sqlite进行 *** 作。

>

缓存模块:通过简单的配置及设计可以很好的实现缓存,对缓存可以随意的配置

缓存模块:imageview加载的时候无需考虑加载过程中出现的oom和android容器快速滑动时候出现的错位等现象。

配置器模块:可以对简易的实现配对配置的 *** 作,目前配置文件可以支持Preference、Properties对配置进行存取。

日志打印模块:可以较快的轻易的是实现日志打印,支持日志打印的扩展,目前支持对sdcard写入本地打印、以及控制台打印

下载器模块:可以简单的实现多线程下载、后台下载、断点续传、对下载进行控制、如开始、暂停、删除等等。

网络状态检测模块:当网络状态改变时,对网络状态进行检测。

1:首选工具pl/sqldeveloper

PL/SQLDeveloper是一种集成的开发环境,专门用于开发、测试、调试和优化OraclePL/SQL存储程序单元,比如触发器等。PL/SQLDeveloper功能十分全面,大大缩短了程序员的开发周期

2:OracleSQLDeveloper是一个免费的,并完全支持图形数据库开发工具。使用SQLDeveloper,您可以浏览数据库对象,运行SQL语句和SQL脚本,编辑和调试PL/SQL语句。您还可以运行任何报告的数量,以及创建和保存您自己的的。SQLDeveloper可以提高工作效率并简化数据库开发任务。

MongoDB。MongoDB是由10gen公司开发的一个介于关系数据库和非关系数据库,这款数据依靠强大的动力,和极快的运算成为手机开发中常用的数据库。数据库是“按照数据结构来组织、存储和管理数据的仓库”。是一个长期存储在计算机内的、有组织的、可共享的、统一管理的大量数据的集合。

<php

//数据导入表(表字段类型要符合)

mysql_query("load data infile '文件路径' into table 表名");

//获取号码

$tel = $_POST['tel'];

//查询姓名

$sql = "select from 表名 where tel='$tel'";

$rec = mysql_query($sql);

$i=0;

while($row = mysql_fetch_array($rec)){

$array[$i]['name'] = $row['name'];

$i++;

}

//输出数组

print_r($array);

>

以上就是关于安卓需要存一些参数信息、测量数据和计算结果,File和SQlite哪个好全部的内容,包括:安卓需要存一些参数信息、测量数据和计算结果,File和SQlite哪个好、android开发怎么存储数据、有哪些比较好的AndroidSQLite开源工具类(android中的sqlite数据库具有哪些特点)等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10094085.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-05
下一篇 2023-05-05

发表评论

登录后才能评论

评论列表(0条)

保存