安卓小程序用到了sqlite数据库,有添加数据的功能,但是只在虚拟机上能成功,在手机就无法成功,这

安卓小程序用到了sqlite数据库,有添加数据的功能,但是只在虚拟机上能成功,在手机就无法成功,这,第1张

先确定手机是否有ROOT权限,可以直接下载 ROOT精灵 下载地址: http://www.sjroot.com/home/

获取Root权限后,下载RE管理器http://shouji.baidu.com/soft/item?docid=6865576&from=web_alad_6 到安卓手机,安装好后打开

找到data文件夹,长按以打开选项,找到权限设定

把所有的 读写 打上勾 ,设置完后确定,这时在回到电脑的eclipse上,data文件就能打开了

1. SQLite数据特点

(1)SQLite数据库是开源的嵌入式数据库,无需独立的数据库引擎,直接嵌入到应用程序进程中,因此,通过API,应用程序可以直接 *** 作它。

(2)事务的处理是原子的,一致的,独立的,可持久化的(ACID),即使在系统崩溃和掉电后。

(3)SQLite数据库通过独占性与共享锁来实现事务的独立处理。

(4)一个单独的跨平台的磁盘文件就能够存储一个数据库。

(5)能支持2TB级的数据。

(6)自包含,无外部依赖性。

(7)支持NULL,INTEGER,NUMERIC,REAL,TEXT和BLOG等数据类型。

(8)SQLite数据库没有用户帐户的概念。数据库的权限仅依赖于文件系统。

2. SQLite数据库的基本 *** 作

(1)建立数据库

sqlite3 data.sqlite3

在当前目录下建立了名为data.sqlite3的数据库。

(2)建立数据表

create table call_list (id INTEGER PRIMARY KEY, type NUMERIC,telnum NUMERIC,bttime TEXT,tcount NUMERIC,charge_rate NUMERIC,charge_sum NUMERIC)

建立了名为 call_list的数据表,有7个字段,分别为id,type,telnum,bttime,tcount,charge_sum.charge_rate.

(3)向数据表中插入数据

insert into call_list values ($num,1,2,'new',4,5,6)

(4)查询数据表中的数据

select * from call_list

(5)修改call_list表中的数据

update call_list set id=00001000 where id=10001

(6)删除表中的数据记录

delete from call_list where id=1000

(7)SQlite中的其它常用命令

.tables -列出所有的数据库中的数据表

.schema tablename -列出指定数据表的结构

.quit -离开数据库

(8)SQLite数据库的导入与导出

a.将data.sqlite数据库的数据全部导出:

sqlite3 data.sqlite

>.output dd.sql

>.dump

这样,数据就保存在dd.sql的文件中,注意这个文件不是数据库,而是SQL语句。

然后再把这些数据导入到另外一个数据库data1.sqlite数据库中。

sqlite3 data1.sqlite

>.read dd.sql

这样,数据就从data.sqlite数据库复制到data1.sqlite数据库中去了。

b.将数据表中的数据导出到a.txt中去

.output a.txt //输出重定向到a.txt

select * from call_list

c.将导出的表中的数据导入到另一个数据库的新建的表中去

如:当从data.sqlite中的call_list表中导出了数据,再导入到另外一个数据库表call中去。

首先建立表call.

然后.import a.txt call 即可。

3. C语言 *** 作Sqlite数据库

API:

int sqlite3_open(const char* filename,sqlite3**ppdb)

第一个参数用来指定数据库文件名。

第二个参数是一个数据库标识符指针。

如果打开数据库成功,则返回0,否则返回一个错误代码。

int sqlite3_close(sqlite3*)

传递的参数是数据库标识符指针用来关闭数据库, *** 作成功是返回0,否则返回一个错误代码。

int sqlite3_errcode(sqlite3*db)

const char* sqlite3_errmsg(sqlite3* db)

const char* sqlite3_errmsg16(sqlite3* db)

这三个函数都是返回错误信息,第一个函数返回的是最近调用数据库接口的错误代码,第二,第三个函数是返回最近调用数据库接口的错误信息。第二个函数返回的错误信息是用UTF-8编码的,第三个函数返回的错误信息是用UTF-16编码的。

int sqlite3_exec(sqlite3*,const char*sql,int(*callback)(void*,int,char**,char**),void*,**errmsg)

这个函数非常重用,是用来执行SQLite数据库的SQL语句的。

第一个参数是sqlite数据库标识符指针。

第二个参数是要执行的SQL语句。

第三个参数是一个回调函数,在执行查询 *** 作时用到,其它的 *** 作可以传空值即NULL。

第四个参数是传递给回调函数第一个参数的实参。

第五个参数是一个错误信息。


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

原文地址: https://outofmemory.cn/yw/12200687.html

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

发表评论

登录后才能评论

评论列表(0条)

保存