在开发中有时我们须要把数据库文件打包到我们的项目中。一般我们都是在外部用工具生成数据库文件,然后拉入项目中。可是我们在程序中查找改文件时。返回的路径总是nil

解决的方法:

原因我们拉入其它资源文件(比方:图片、代码文件等)Xcode都会自己主动加入到target 的 "Build Phases" 下 "Copy Bundle Resources文件夹下,可是我们拉过来的数据库文件这里是找不到的,可能是Xcode无法识别这类文件(当我们拉去过来时)。所以我们要做的就是把刚才加入的db文件加入该文件夹下。如图

这样就OK了。执行代码就能够找到了该数据库文件的路径了。

接下来上代码:

- (void)_testDataBaseHandle
{
static NSString *const DATABASE_FILE_NAME = @"exiu.db";
NSString *dbFilePath ;
//获取应用程序的路径
NSArray *searchPaths = NSSearchPathForDirectoriesInDomains(
NSDocumentDirectory,
NSUserDomainMask,
YES);
NSString *documentFolderPath = [searchPaths objectAtIndex:0];
NSLog(@"docoumentFolderPath=%@",documentFolderPath); //往应用程序路径中加入数据库文件名,把它们拼接起来。 这里用到了宏定义(目的是不易出错)
dbFilePath = [documentFolderPath stringByAppendingPathComponent:DATABASE_FILE_NAME];
NSLog(@"dbFilePath = %@",dbFilePath); // /*
为什么要往应用程序里加入数据库文件这个过程:
由于以下要进行推断,会依据这个路径去查找应用程序的路径中究竟有没有这个文件,
假设有。则不用在此拷贝了。
假设没有,则又一次拷贝一次。
数据库文件必须加入进取,否则无法进行数据库的操作,并且必须加入一次, 那么为什么必需要加入一次呢?
由于我们在程序中实现对数据库的改动,然而却又把数据库加入了一次,
那么新加入的数据库就会把旧的数据库覆盖掉,那么程序中对数据库的改动也不能实现,
所以数据库仅仅能加入一次且是在程序执行初加入
*/ //依据上面拼接好的路径 dbFilePath ,利用NSFileManager 类的对象的fileExistsAtPath方法来检測是否存在,返回一个BOOL值
//1. 创建NSFileManager对象 NSFileManager包括了文件属性的方法
NSFileManager *fm = [NSFileManager defaultManager]; //2. 通过 NSFileManager 对象 fm 来推断文件是否存在,存在 返回YES 不存在返回NO
BOOL isExist = [fm fileExistsAtPath:dbFilePath];
//- (BOOL)fileExistsAtPath:(NSString *)path; //假设不存在 isExist = NO,拷贝project里的数据库到Documents下
if (!isExist)
{
//拷贝数据库 //获取project里。数据库的路径,由于我们已在project中加入了数据库文件,所以我们要从project里获取路径
NSString *backupDbPath = [[NSBundle mainBundle]
pathForResource:@"exiu"
ofType:@"db"];
//这一步实现数据库的加入。
// 通过NSFileManager 对象的复制属性。把project中数据库的路径拼接到应用程序的路径上
BOOL cp = [fm copyItemAtPath:backupDbPath toPath:dbFilePath error:nil];
NSLog(@"cp = %d",cp);
//- (BOOL)copyItemAtPath:(NSString *)srcPath toPath:(NSString *)dstPath error:(NSError **)error
NSLog(@"backupDbPath =%@",backupDbPath);
if (cp) {
NSError *error;
//这里验证程序执行时,copy成功后,删除mainbundle里的文件
BOOL bl = [fm removeItemAtPath:backupDbPath error:&error]; } }
NSLog(@"isExist =%d",isExist);
}

以下说说copy文件成功后。删除main bundle下的源文件的可行性

假设是在模拟器下,你执行发现是能够的!这样并不意味着在真机上是可行的。经过真机測试。发现会报错。!

由于程序在真机真机上执行时,bundle 是仅仅读的。所以千万不要执行时改动程序bundle下的不论什么文件!!

上面说到,程序执行时。程序bundle是仅仅读的,这也是我们为什么要把数据文件copy到Document文件加下的原因!

我们这个数据文件肯定是要进行增删改查操作的。

參考:http://stackoverflow.com/questions/21507028/ios-sqlite-db-path-from-nsbundle-mainbundle-returns-null

http://stackoverflow.com/questions/9002208/sqlite-db-path-in-bundle-acces

http://www.mindfiresolutions.com/Never-try-to-delete-any-resource-from-NSBundle-in-iPhoneiPadiPod-on-runtime-1523.php

iOS 把数据库文件打包到mainbundle中,查找不到路径的解决的方法;以及在删除bundle中文件的可行性的更多相关文章

  1. mysql导入导出数据中文乱码解决方法小结(1、navicat导入问题已解决,创建连接后修改连接属性,选择高级->将使用Mysql字符集复选框去掉,下拉框选择GBK->导入sql文件OK;2、phpmyadmin显示乱码的问题也解决,两步:1.将sql文件以utf8的字符集编码另存,2.将文件中sql语句中的字段字符集编码改成utf8,导入OK)

    当向 MySQL 数据库插入一条带有中文的数据形如 insert into employee values(null,'张三','female','1995-10-08','2015-11-12',' ...

  2. 批处理文件中获取当前所在路径的几种方法,以及写文件到txt

    @echo off setlocal EnableDelayedExpansion echo 当前正在运行的批处理文件所在路径:!cd! pause @echo off echo 当前目录是:%cd% ...

  3. 【方法1】删除Map中Value反复的记录,而且仅仅保留Key最小的那条记录

    介绍 晚上无聊的时候,我做了一个測试题,測试题的大体意思是:删除Map中Value反复的记录,而且仅仅保留Key最小的那条记录. 比如: I have a map with duplicate val ...

  4. 【IDEA】IDEA中配置tomcat虚拟路径的两种方法

    首先要确保使用的是本地的tomcat服务器,而不是maven插件. -------------------------第一种:使用IDEA工具自动配置(推荐这种)------------------- ...

  5. android中常见的内存泄漏和解决的方法

    android中的内存溢出预计大多数人在写代码的时候都出现过,事实上突然认为工作一年和工作三年的差别是什么呢.事实上干的工作或许都一样,产品汪看到的结果也都一样,那差别就是速度和质量了. 写在前面的一 ...

  6. struts.xml中出现extends undefined package struts-default解决的方法

    在struts.xml中出现extends undefined package struts-default,经过查阅资料原来是由于没有联网的缘故. 这样解决:在myeclipse中关联本地的dtd文 ...

  7. 关于在linux下出现stdio.h文件不存在等gcc标准库不能找到的解决的方法

    首先说明一下我的系统配置:ubuntu 12.04     gcc 4.6.3 有几天没有使用ubuntu了,今天拿出来编程序,刚開始编译一个uboot1.1.6的代码.出现了stdio.h:没有那么 ...

  8. 【方法2】删除Map中Value反复的记录,而且仅仅保留Key最小的那条记录

    依据guigui111111的建议:先把Map按Key从大到小排序,然后再把Key和Value互换.这也是一种非常好的思路,我写了一下代码,顺便贴上来,供大家參考与分享. package shuai. ...

  9. Windows中查找命令的路径 (类似Linux中的which命令)

    where is a direct equivalent: C:\Users\Joey>where cmdC:\Windows\System32\cmd.exeNote that in Powe ...

随机推荐

  1. docker+Battery Historian 环境搭建(电量分析)

    docker 安装(windows) 1.  下载 https://docs.docker.com/docker-for-windows/install/  和 安装和添加环境变量(...) 2. 安 ...

  2. 路由重分发 最重要 最难 ccnp

    路由重分发   多种协议之间    彼此学习到对方的路由 重分发好   结果好 重分发不好   结果最好是产生次优路径      最差事产生路由黑洞和环路 实例1:    重分发一般需要双向重分发   ...

  3. 【软考2】Java语言的基本知识汇总

    导读:现在对于java这一模块,还没有相应的项目经验,只是通过各种类型的资料,对java有一个面上的了解.现在,对此做一个罗列总结,在以后的学习过程中,逐步完善! 一.语言的发展 1.1,机器语言 在 ...

  4. Codeforces Round #401 (Div. 2) 离翻身就差2分钟

    Codeforces Round #401 (Div. 2) 很happy,现场榜很happy,完全将昨晚的不悦忘了.终判我校一片惨白,小董同学怒怼D\E,离AK就差一个C了,于是我AC了C题还剩35 ...

  5. 九度oj 题目1528:最长回文子串

    题目描述: 回文串就是一个正读和反读都一样的字符串,比如“level”或者“noon”等等就是回文串. 回文子串,顾名思义,即字符串中满足回文性质的子串. 给出一个只由小写英文字符a,b,c...x, ...

  6. 【Luogu】P1119灾后重建(Floyd)

    题目链接 见题解: feilongz. 这里只放代码. #include<cstdio> #include<cstring> #include<cstdlib> # ...

  7. Ubuntu安装 Docker CE,VNC访问docker图形界面并安装ROS

    从包安装 如果您无法使用Docker的存储库来安装Docker CE,则可以下载.deb适用于您的发行版的 文件并手动安装.每次要升级Docker CE时都需要下载新文件. 安装Docker CE,将 ...

  8. BZOJ 4824 [Cqoi2017]老C的键盘 ——树形DP

    每一个限制条件相当于一条有向边, 忽略边的方向,就成了一道裸的树形DP题 同BZOJ3167 唯一的区别就是这个$O(n^3)$能过 #include <map> #include < ...

  9. servlet分析

    Servlet生命周期分为三个阶段: 1,初始化阶段  调用init()方法 2,响应客户请求阶段 调用service()方法 3,终止阶段 调用destroy()方法 Servlet初始化阶段: 在 ...

  10. 「CodePlus 2018 4 月赛」最短路

    $n \leq 100000$,$m \leq 500000$的有向图,两点之间还可以以$a \ \ xor \ \ b$的代价从$a$到$b$,问$s$到$t$的最短路. 被自己蠢哭QAQ 首先两个 ...