iPhone开发之SQLite使用详解_Ubuntu_青云站长教程网
欢迎来到站长教程网!
  • 秒到短信接口 免费试用
  • 微信支付宝接口 秒结算
  • 中文网站排名|申请加入
  • 搜索引擎全站查询
  • 查询移动网站权重数据
  • 海外主机 台湾公司直销
  • Ubuntu

    当前位置:主页 > 服务器教程 > Ubuntu >

    iPhone开发之SQLite使用详解

    时间:2019-11-09|栏目:Ubuntu|点击:
  • SQLite是一个开源的嵌入式关系数据库,它在2000年由D. Richard Hipp发布,它的减少应用程序管理数据的开销,SQLite可移植性好,很容易使用,很小,高效而且可靠。

    SQLite嵌入到使用它的应用程序中,它们共用相同的进程空间,而不是单独的一个进程。从外部看,它并不像一个RDBMS,但在进程内部,它却是完整的,自包含的数据库引擎。

    嵌入式数据库的一大好处就是在你的程序内部不需要网络配置,也不需要管理。因为客户端和服务器在同一进程空间运行。SQLite 的数据库权限只依赖于文件系统,没有用户帐户的概念。SQLite 有数据库级锁定,没有网络服务器。它需要的内存,其它开销很小,适合用于嵌入式设备。你需要做的仅仅是把它正确的编译到你的程序。

    ios下使用sqlite首先导入SQLite3.0的lib库。然后包含头文件#import <sqlite3.h>

    下面的代码主要对常用的数据库操作如查询、插入、删除、更新等进行封装,方便以后使用。

    头文件代码如下:

    #import <Foundation/Foundation.h>    #import <sqlite3.h>    #import "User.h"       #define kFileName @"database.sqlite"       @interface SQLite3Util : NSObject{       sqlite3_stmt *stmt;       sqlite3 *database;   }      - (NSString *)dataFilePath;   - (int)getCountOfDB;   - (BOOL)insertOrUpdateUser:(NSString *)sql;   - (BOOL)deleteUser:(NSInteger)userId;   - (NSMutableArray *)getUsers;   - (User *)getUser:(NSInteger)userId;   - (BOOL)openDatabase;   - (void)closeDatabase;   @end  

    实现如下:

    #import "SQLite3Util.h"    @implementation SQLite3Util         //Return Database path    - (NSString *)dataFilePath{       NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUSErDomainMask, YES);       NSString *documentsDirectory = [paths objectAtIndex:0];       return [documentsDirectory stringByAppendingPathComponent:kFileName];   }      //Insert or update data    - (BOOL)insertOrUpdateUser:(NSString *)sql{       if ([self openDatabase]) {           if (sqlite3_exec(database, [sql UTF8String], nil, &stmt, nil) != SQLITE_OK) {               NSLog(@"Insert or update is failed!");               return NO;           }else{   //            sqlite3_finalize(stmt);                NSLog(@"Insert or update successfully!");               return YES;           }           sqlite3_close(database);                  }       return NO;   }      //Delete a user from database    - (BOOL)deleteQuestion:(NSInteger)userId{       NSString *sql = [NSString stringWithFormat:@"Delete FROM User WHERE id = %i", userId];       if ([self openDatabase]) {           if (sqlite3_exec(database, [sql UTF8String], nil, &stmt, nil) != SQLITE_OK) {               NSLog(@"Delete data is failed!");               return NO;           }else{               sqlite3_finalize(stmt);               NSLog(@"Delete data successfully!");               return YES;           }           sqlite3_close(database);       }       return NO;   }   //Get users    - (NSMutableArray *)getUsers{       NSMutableArray *users = [[NSMutableArray alloc] init];       NSString *sql = [NSString stringWithFormat:@"SELECT * FROM User];       if ([self openDatabase]) {           if (sqlite3_prepare_v2(database, [sql UTF8String], -1, &stmt, nil) == SQLITE_OK) {   //            NSLog(@"SQL is Prepared!");                while (sqlite3_step(stmt) == SQLITE_ROW) {                   User *user = [[Question alloc] init];                   char *name = (char *)sqlite3_column_text(stmt, 0);                   [user setName:[NSString stringWithUTF8String:name]];                   char *index = (char *)sqlite3_column_text(stmt, 1);                   [user setId:[[NSString stringWithUTF8String:index] intValue]];                   [users addObject: user];               }               sqlite3_finalize(stmt);           }       }       sqlite3_close(database);       return users;   }      //Get count of the users    - (int)getCountOfDB{       int count = 0;       NSString *sql = [NSString stringWithFormat:@"SELECT * FROM User"];        if ([self openDatabase]) {           if (sqlite3_prepare_v2(database, [sql UTF8String], -1, &stmt, nil) == SQLITE_OK) {               while (sqlite3_step(stmt) == SQLITE_ROW) {                   count ++;               }               sqlite3_finalize(stmt);           }       }       return count;   }      - (User *)getUser:(NSInteger)userId{       User *user = [[User alloc] init];       NSString *sql = [NSString stringWithFormat:@"SELECT * FROM User WHERE id = %i", userId];   //    NSLog(@"sql = %@", sql);        if ([self openDatabase]) {           if (sqlite3_prepare_v2(database, [sql UTF8String], -1, &stmt, nil) == SQLITE_OK) {               NSLog(@"SQL is Prepared!");               while (sqlite3_step(stmt) == SQLITE_ROW) {                   char *name = (char *)sqlite3_column_text(stmt, 0);                   [user setName:[NSString stringWithUTF8String:name]];                   [user setId:userId];               }               sqlite3_finalize(stmt);           }       }       return user;   }      - (BOOL)openDatabase{       if (sqlite3_open([[self dataFilePath] UTF8String], &database) == SQLITE_OK) {           NSLog(@"SQL is Open!");           return YES;       }       return NO;   }      - (void)closeDatabase{       sqlite3_close(database);   }   @end  

    在以后的代码中直接调用即可,如查询一个用户:

    上一篇:Android中用Application类实现全局变量

    栏    目:Ubuntu

    下一篇:iPhone开发之Json数据的解析

    本文标题:iPhone开发之SQLite使用详解

    本文地址:http://www.jh-floor.com/fuwuqijiaocheng/Ubuntu/123576.html

    广告投放 | 联系我们 | 版权申明

    重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

    如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

    联系QQ:888888 | 邮箱:888888#qq.com(#换成@)

    Copyright © 2002-2017 青云站长教程网 版权所有 琼ICP备xxxxxxxx号