如何将数据库文件加载到手机文件中

手机本地数据库(存储手机中文件) - 青春浪 - 博客园
MediaStore 这个类是android系统提供的一个多媒体数据库,android中多媒体信息都可以从这里提取。这个MediaStore包括了多媒体数据库的所有信 息,包括音频,视频和图像,android把所有的多媒体数据库接口进行了封装,所有的数据库不用自己进行创建,直接调用利用 ContentResolver去掉用那些封装好的接口就可以进行数据库的操作了。今天我就介绍一些这些接口的用法。& & 首先,要得到一个ContentResolver实例,ContentResolver可以这样获取,利用一个Activity或者Service的 Context即可。如下所示:
& & ContentResolver mResolver = ctx.getContentResolver();
&上面的那个ctx的就是一个context,Activity.this就是那个Context,这个Context就相当于一个上下文环境。得到这个
Context后就可以调用getContentResolver接口获取ContentResolver实例了。ContentResolver实例获
得后,就可以进行各种查询,下面我就以音频数据库为例讲解增删改查的方法,视频和图像和音频非常类似。
在讲解各种查询之前,我给大家介绍下怎么看android都提供了哪些多媒体表。在adbshell中,找到/data/data
/com.android.providers.media/databases/下,然后找到SD卡的数据库文件(一般是一个.db文件),然后输入命
令sqlite3加上这个数据库的名字就可以查询android的多媒体数据库了。.table命令可以列出所有多媒体数据库的表,.scheme加上表
名可以查询表中的所有列名。这里可以利用SQL语句来查看你想要的数据,记得最后一定要记住每条语句后面都加上分号。下面开始讲述怎么在这些表上进行增删
& & 查询,代码如下所示:
& & Cursor cursor = resolver.query(_uri, prjs, selections, selectArgs, order);
& & ContentResolver的query方法接受几个参数,参数意义如下:
&Uri:这个Uri代表要查询的数据库名称加上表的名称。这个Uri一般都直接从MediaStore里取得,例如我要取所有歌的信息,就必须利用
MediaStore.Audio.Media.
EXTERNAL_CONTENT_URI这个Uri。专辑信息要利用
MediaStore.Audio.Albums.EXTERNAL_CONTENT_URI这个Uri来查询,其他查询也都类似。
& & Prjs:这个参数代表要从表中选择的列,用一个String数组来表示。
& &&&Selections:相当于SQL语句中的where子句,就是代表你的查询条件。
& & selectArgs:这个参数是说你的Selections里有?这个符号是,这里可以以实际值代替这个问号。如果Selections这个没有?的话,那么这个String数组可以为null。
& &&&Order:说明查询结果按什么来排序。
& & 上面就是各个参数的意义,它返回的查询结果一个Cursor,这个Cursor就相当于数据库查询的中Result,用法和它差不多。
-------------------------------------------------------------------------------------------------------------------&
& & 增加,代码如下所以:
& & ContentValues values = new ContentValues();
& & values.put(MediaStore.Audio.Playlists.Members.PLAY_ORDER,0);
& & resolver.insert(_uri, values);
& & 这个insert传递的参数只有两个,一个是Uri(同查询那个Uri),另一个是ContentValues。这个ContentValuses对应于数据库的一行数据,只要用put方法把每个列的设置好之后,直接利用insert方法去插入就好了。
& & 更新,代码如下:
& & ContentResolver resolver = ctx.getContentResolver();
& & Uri uri = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI;
& & ContentValues values = new ContentValues();
& & values.put(MediaStore.Audio.Media.DATE_MODIFIED, sid);
& & resolver.update(MediaStore.Audio.Playlists.EXTERNAL_CONTENT_URI,values, where, selectionArgs);
& & 上面update方法和查询还有增加里的参数都很类似,这里就不再重复叙述了,大家也可直接参考google的文档,那里也写的很清楚。
& & 删除,代码如下:
& & ContentResolver resolver = ctx.getContentResolver();
& && &resolver.delete(MediaStore.Audio.Playlists.EXTERNAL_CONTENT_URI,where, selectionArgs);
& & delete和更新的方法很类似,大家对照更新的方法看下马上就会明白。
阅读(...) 评论()他的最新文章
他的热门文章
您举报文章:
举报原因:
原文地址:
原因补充:
(最多只允许输入30个字)手机开发-如何查看android数据文件_百度经验
&&&&&&&&&电脑软件手机开发-如何查看android数据文件?听语音1234567
百度经验:jingyan.baidu.com在Android中可以使用Eclipse插件DDMS来查看,也可以使用Android工具包中的adb工具来查看。android项目中的sqlite数据库位于/data/data/项目包/databases中。百度经验:jingyan.baidu.comdoc命令adb工具,eclipse插件百度经验:jingyan.baidu.com1使用DDMS导出sqlite数据库。1、首先打开android项目的调试模式,然后找到显示DDMS:选择DDMS2、切换到DDMS,显示File Explorer窗口,找到/data/data/然后找到程序包的文件夹,打开databases,就能看到sqlite数据库文件了。选择将其导出。这样就把sqlite数据库文件以文件的方式导出来了,然后使用sqlite界面管理工具如sqlite administrator、sqlite man或者firefox插件sqlite manager等打开就可以了。2使用adb工具访问sqlite数据库Android Debug Bridge(ADB)是Android的一个通用调试工具,它可以更新设备或模拟器中的代码,可以管理预定端口,可以在设备上运行shell命令,我们知道android是基于Linux内核,它的内部文件结构也是采用linux文件组织方式,因此访问它的文件结构需要使用shell。这次我们就会用shell来访问android应用中的sqlite数据库文件。1、运行cmd,切换到android-sdk目录,运行adb.exe,加上参数shell,出现#号就代表进入了shell命令模式,注意adb要在Android模拟器运行时才能进入shell:2、shell命令记住两个基本命令ls和cd,类似windows命令提示行中的dir和cd,代表列出当前目录下文件列表和进入到指定目录。了解这两个命令之后,就可以找到data/data/项目包名/databases:找到数据库文件:接下来就是使用sqlite管理工具来进行操作了。键入sqlite3 数据库名就进入了sqlite管理模式了。在android的sdk中自带了sqlite3.exe,这是sqlite的官方管理工具,它是一个命令行工具。为了使用方便,将其路径注册到系统环境变量path中,即将;%Android_Home%加在Path中,这样只样运行sqlite3,就能直接打开sqlite管理工具了。3sqlite管理数据库篇sqlite命令行工具默认是以;结束语句的。所以如果只是一行语句,要在末尾加;,或者在下一行中键入;,这样sqlite命令才会被执行。sqlite常用命令:.tables--查看数据库的表列表.exit--退出sqlite命令行其他命令可随时.help查看帮助。sql命令可直接在此命令行上执行即可:END经验内容仅供参考,如果您需解决具体问题(尤其法律、医学等领域),建议您详细咨询相关领域专业人士。投票(2)已投票(2)有得(0)我有疑问(0)◆◆说说为什么给这篇经验投票吧!我为什么投票...你还可以输入500字◆◆只有签约作者及以上等级才可发有得&你还可以输入1000字◆◆如对这篇经验有疑问,可反馈给作者,经验作者会尽力为您解决!你还可以输入500字相关经验401010热门杂志第1期你不知道的iPad技巧3700次分享第1期win7电脑那些事6536次分享第2期新人玩转百度经验1371次分享第1期Win8.1实用小技巧2628次分享第1期小白装大神1870次分享◆请扫描分享到朋友圈连真实手机后建立的sqlite数据库存放在什么文件夹下面?【android开发吧】_百度贴吧
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&签到排名:今日本吧第个签到,本吧因你更精彩,明天继续来努力!
本吧签到人数:0成为超级会员,使用一键签到本月漏签0次!成为超级会员,赠送8张补签卡连续签到:天&&累计签到:天超级会员单次开通12个月以上,赠送连续签到卡3张
关注:122,192贴子:
连真实手机后建立的sqlite数据库存放在什么文件夹下面?收藏
麻烦各位大神们,我做了一个应用,需要用到sqlite数据库,为什么连上自己真实手机后建立的sqlite不知道在哪里,但是我用模拟器来运行的时候数据库是有的,我也知道存在哪里,而且可以在listview里面显示出我的数据,可是我用真实手机的时候就不知道创建的sqlite在哪里,而且在listview里面也没有数据显示。为什么?
安卓开发技术新,市场占有率大!慕课网专业讲师全力打造Android入门到精通课程!系统化学习,精心服务,结合真实开发案例,提升学习效果,带你快速入行!直达名企!
把写好的数据.db文件放到raw文件夹里,用io流写进数据就可以了。
自己用sqlite查看器就能查看手机下的数据库,不过要root- -,不然没权限
在data下,要root
这是Root Explorer没有获取到Root权限。
ddms→data→data→package→database
根目录-data-data-包名-databases
怎么解决的?遇到同样问题,偶是初学者,刚入门!谢谢回复
手机没有访问权限
adb shell$ su# cd /data/data/com.android.providers.settings/databases/# sqlite3 settings.dbsqlite& .head onsqlite& .mode columnsqlite& .timer onsqlite& .width 0 50 50sqlite& .tablessqlite& select *
android开发上快包提供APP/网站/微信/EAP等开发服务让服务商主动报价,500个软件行业成功案例,高品质定制开发服务平台!
是的,没权限,我5.0
提示:没有sqlite3
登录百度帐号推荐应用如何从android手机中把自己的数据库给COPY出来_百度知道
如何从android手机中把自己的数据库给COPY出来
我有更好的答案
data/com.hello/databases/test.getChannel().transferTo(0, f.length();).db&}Toast.makeText(mainpage.String sdcardPath = Environment.getExternalStorageDirectory();/data&#47.getAbsolutePath(),直接文件复制就行,大概如下;try {outF = new FileOutputStream(o); &#47, &完成&;/sdcard上的目标地址if(f.db&quot.getChannel();new FileInputStream(f),outF);比如
&quot:File f = new File(&quot, Toast.LENGTH_SHORT).show()自己的应用复制自己的数据库,无需File o = new File(sdcardPath+&cp.exists()) {FileChannel outF;} catch (FileNotFoundException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();data/应用的包名/databases/数据库名&); ///data&#47
【0元入学,两周免费试听】
主营:培训【Python+人工智能,Java大数据,HTML5】
为您推荐:
其他类似问题
换一换
回答问题,赢新手礼包
个人、企业类
违法有害信息,请在下方选择后提交
色情、暴力
我们会通过消息、邮箱等方式尽快将举报结果通知您。}

我要回帖

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信