问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

ios 怎么打开sqlite数据库

发布网友 发布时间:2022-04-28 18:34

我来回答

1个回答

热心网友 时间:2022-04-08 05:34

ITJOB题库中也有这道题,大概过程是这样。新建Empty Appliation,添加一个HomeViewController,和一个组件libsqlite3.dylib,来支持对sqlite3的连接,关闭,增删改查等操作。
1. HomeViewController.h代码:
#import <UIKit/UIKit.h>
#import "sqlite3.h"
@interface HomeViewController : UIViewController{
sqlite3 *db; //声明一个sqlite3数据库
}
- (NSString *)filePath;//数据库文件的路径。一般在沙箱的Documents里边操作
@end

2. HomeViewController.m代码:
#import "HomeViewController.h"
@interface HomeViewController ()
@end
@implementation HomeViewController
//该方法用于返回数据库在Documents文件夹中的全路径信息
- (NSString *)filePath{
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *documentsDir = [paths objectAtIndex:0];
return [documentsDir stringByAppendingPathComponent:@"Contacts.sqlite"];
}
//打开数据库的方法
- (void)openDB{
if (sqlite3_open([[self filePath] UTF8String], &db) != SQLITE_OK) {
sqlite3_close(db);
NSAssert(0, @"数据库打开失败。");
}
}
- (void)getAllContacts{
NSString *sql = @"SELECT * FROM members";
sqlite3_stmt *statement;

if (sqlite3_prepare_v2(db, [sql UTF8String], -1, &statement, nil) == SQLITE_OK) {
while (sqlite3_step(statement) == SQLITE_ROW) {

char *name = (char *)sqlite3_column_text(statement, 0);
NSString *nameStr = [[NSString alloc] initWithUTF8String:name];

char *email = (char *)sqlite3_column_text(statement, 1);
NSString *emailStr = [[NSString alloc] initWithUTF8String:email];

char *birthday = (char *)sqlite3_column_text(statement, 2);
NSString *birthdayStr = [[NSString alloc] initWithUTF8String:birthday];

NSString *info = [[NSString alloc] initWithFormat:@"%@ - %@ - %@",
nameStr, emailStr, birthdayStr];

NSLog(info);

[nameStr release];
[emailStr release];
[birthdayStr release];
[info release];
}
sqlite3_finalize(statement);
}
}
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
为什么word换行的时候不对齐? 老人各类心脏病的急救方法有哪些呢? 老人心脏病突然发作怎么办 老人突发心脏病该如何急救呢? TAO黄子韬 tao什么学校毕业? 红楼梦第14回特色句92句精选 今天出院又入院医保 FPM看这一篇就够了 “更何入他不二门”的出处是哪里 能在原油期货工作的怎么样 swift支持哪些数据库 原油期货难吗?跟境外相比是不是国内好做点? 期货原油好做还是现货原油好做 鸡脚多吃有害吗?? 请问iOS怎么连接网上的MySQL数据库 女人为什么不能吃鸡爪 ios应用可以采用的云数据库有哪些 鸡爪很大是不是不安全?网上买的鸡爪 货到后发现鸡爪好大、有些不敢吃、觉得不正常 iOS开发数据库存储能用FMDB直接存储对象吗 鸡爪为什么不能吃? Android,IOS,WP,Windows,linux通用的数据库有哪些 我矫正牙齿时医生给我说不能吃鸡爪,但是很想吃,真的不能吃吗? 手机app用什么数据库比较好? 什么人不能吃鸡爪芋 梦见妈妈在河边捡鸡蛋煮熟了都坏了我捡到的煮熟了能吃 ios 怎样打开sqlite数据库 我一般不吃泡椒凤爪,我一闻到那种味道就觉得有点特别,不敢吃的那种,可是我偶尔吃红色的鸡爪,就是那种 IOS的数据是如何交互的,用什么建立数据库 不能吃鸡爪,鸭爪.是真的吗 原油期货好做吗? 废弃的起泡胶怎样做假水,只用传说中的1种材料就能做假水? 原油期货投资怎么样?好不好做? 国际原油期货和国内原油期货哪一个好做? 为什么电脑一看电视剧就自动关机? 电脑看几分钟电视剧后就自动关机了,是怎么回事 为什么我的电脑一看电视就会自动关机 看电视剧有时电脑自动关机为什么 有关红军长征的故事有哪些? 荣耀v30好,还是华为nova6好一点? 【招联金融】您本期应还款767.67元,还款日为03月13日。请确保还款银行卡余额? 我家孩子想去日本留学,大概需要多少费用呢? 怎么解绑淘宝的快捷支付? 淘宝支付宝怎么解绑快捷支付银行卡 留学日本费用 一般去日本留学要多少钱? 去日本留学大概需要多少钱? 淘宝可以解除绑定银行卡吗? 手机贷款审批在征信上多久可以消除记录啊 请问怎么能解除淘宝账号的快捷支付和银行卡的绑定?