SQLiteManager數(shù)據(jù)庫

1 創(chuàng)建文件引入

Snip20160524_6.png

2 添加到文件中

Snip20160524_9.png

3 創(chuàng)建一個繼承與NSObject的類

DataBaseHandle.h 文件

#import <Foundation/Foundation.h>

@interface DataBaseHandle : NSObject

//把這個類寫成單例,方便外部使用
+(DataBaseHandle *)shareDataBaseHandle;

- (void)getPath:(NSString *)path;

//打開數(shù)據(jù)庫
-(void)openDB;
//關閉數(shù)據(jù)庫
-(void)closeDB;
//創(chuàng)建表
-(void)creatTable;

//插入數(shù)據(jù)
-(void)insertName:(NSString *)name
           gender:(NSString *)gender
              age:(NSInteger)age;
//通過uid去更新數(shù)據(jù)
-(void)updateWithUID:(NSInteger)uid;
//通過uid去刪除數(shù)據(jù)
-(void)deleteWithUID:(NSInteger)uid;
//查找所有數(shù)據(jù)
-(void)searchAll;
//根據(jù)名字去找找相關數(shù)據(jù)信息
-(void)searchWithName:(NSString *)name;


@end

DataBaseHandle.m 文件

#import "DataBaseHandle.h"
#import <sqlite3.h>

@interface DataBaseHandle ()

//數(shù)據(jù)庫的存儲路徑
@property(nonatomic,strong)NSString *dbPath;

@end

//
static DataBaseHandle *dataBase = nil;

@implementation DataBaseHandle


  • 把這個類寫成單例,方便外部使用
+(DataBaseHandle *)shareDataBaseHandle
{
    if (dataBase == nil) {
        dataBase = [[DataBaseHandle alloc] init];
    }
    return dataBase;
}
  • 懶加載(給數(shù)據(jù)庫路徑)
-(NSString *)dbPath
{
    if (_dbPath == nil) {
        //獲取decoment路徑
        NSString *document = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];
        //在document路徑下創(chuàng)建數(shù)據(jù)庫文件夾
        _dbPath = [document stringByAppendingPathComponent:@"person.sqlite"];
        
    }
    return _dbPath;
}
//因為有很多地方會使用到數(shù)據(jù)庫,所以初始化一個數(shù)據(jù)庫的靜態(tài)變量
static sqlite3 *db = nil;

  • 打開數(shù)據(jù)庫
-(void)openDB
{
    //第一個參數(shù):代表的是數(shù)據(jù)庫的路徑
    //第二個參數(shù):二級指針,代表的是數(shù)據(jù)庫的地址
    int result = sqlite3_open(self.dbPath.UTF8String, &db);
    
    if (result == SQLITE_OK) {
        NSLog(@"數(shù)據(jù)庫打開成功");
    }else
    {
        NSLog(@"數(shù)據(jù)庫打開失敗");
    }
    
}

  • 關閉數(shù)據(jù)庫
-(void)closeDB
{
    int result = sqlite3_close(db);
    
    if (result == SQLITE_OK) {
        NSLog(@"數(shù)據(jù)庫關閉成功");
    }else
    {
        NSLog(@"數(shù)據(jù)庫關閉失敗");
    }
}

  • 創(chuàng)建表
-(void)creatTable
{
   //創(chuàng)建一個person表, 字段uid integer類型 主鍵 自增 不能為空,name text類型,gender text類型,age integer類型
    
    NSString *creatStr = @"create table if not exists person(uid integer PRIMARY KEY AUTOINCREMENT not null,name text,gender text,age integer)";
    
    int result = sqlite3_exec(db, creatStr.UTF8String, NULL, NULL, NULL);
    
    if (result == SQLITE_OK) {
        NSLog(@"建表成功");
    }else
    {
        NSLog(@"建表失敗");
    }
    
    NSLog(@"_dbPath = %@",self.dbPath);
}

  • 插入數(shù)據(jù)
-(void)insertName:(NSString *)name
           gender:(NSString *)gender
              age:(NSInteger)age
{

    //當values不確定的情況下使用 ? 代替
    //準備sql語句
     NSString *insertStr = @"insert into person(name,gender,age)values(?,?,?)";
    //伴隨指針
    sqlite3_stmt *stmt = nil;
    
    //第一個參數(shù):數(shù)據(jù)庫
    //第二個參數(shù):sql語句
    //第三個參數(shù):語句長度,有正負之分,1:代表往后讀取一個字節(jié),如果為-1的話,那么會自動判斷語句長度
    int result = sqlite3_prepare(db, insertStr.UTF8String, -1, &stmt, NULL);
    //判斷執(zhí)行結果
    if (result == SQLITE_OK) {
        //在操作成功的方法里面進行 ? 值的綁定設置
        //第一個參數(shù):伴隨指針
        //第二個參數(shù): ? 的位置,從1開始.
        //第三個參數(shù):表示要插入的值
        //第四個參數(shù):-1
        sqlite3_bind_text(stmt, 1, name.UTF8String, -1, NULL);
        sqlite3_bind_text(stmt, 2, gender.UTF8String, -1, NULL);
        sqlite3_bind_int64(stmt, 3, age);
        
        
        //sql語句執(zhí)行完畢
        //執(zhí)行伴隨指針,根據(jù)伴隨指針的情況判斷是否插入成功
        //SQLITE_DONE 代表插入數(shù)據(jù)是否成功
        if (sqlite3_step(stmt) == SQLITE_DONE) {
            NSLog(@"插入成功");
        }else
        {
            NSLog(@"插入失敗");
        }
    }
    //一定要記得釋放伴隨指針
    sqlite3_finalize(stmt);
    
}

  • 通過uid去更新數(shù)據(jù)
-(void)updateWithUID:(NSInteger)uid
{
   NSString *updateStr = @"update person set name = '隔壁老王' where uid = ?";
    //創(chuàng)建伴隨指針
    sqlite3_stmt *stmt = nil;
    //準備sql函數(shù)
    int result = sqlite3_prepare(db, updateStr.UTF8String, -1, &stmt, NULL);
    
    if (result == SQLITE_OK) {
        //綁定:
        sqlite3_bind_int64(stmt, 1, uid);
        //執(zhí)行完畢
        if (sqlite3_step(stmt) == SQLITE_DONE) {
            NSLog(@"數(shù)據(jù)庫更新成功");
        }else
        {
            NSLog(@"數(shù)據(jù)庫更新失敗");
        }
    }
    sqlite3_finalize(stmt);
    
}
  • 通過uid去刪除數(shù)據(jù)
-(void)deleteWithUID:(NSInteger)uid
{

    //準備sql語句
    NSString *deleteStr = [NSString stringWithFormat:@"delete from person where uid = %ld",uid];
    
    //sql函數(shù)
    int result = sqlite3_exec(db, deleteStr.UTF8String, NULL, NULL, NULL);
    if (result == SQLITE_OK) {
        NSLog(@"刪除成功");
    }else
    {
        NSLog(@"刪除失敗");
    }
    
    
    
}
  • 查找所有數(shù)據(jù)

-(void)searchAll
{
//準備sql語句
    NSString *searchAllStr = @"select * from person";
    //未完待續(xù) 

}


  • 根據(jù)名字去查找相關數(shù)據(jù)信息
-(void)searchWithName:(NSString *)name
{
    //準備sql語句
    NSString *searchStr = @"select * from person where name = ?";
    
       //未完待續(xù)  ,自己想把
 
}
@end

ViewController中調用

 DataBaseHandle *dataBase = [DataBaseHandle shareDataBaseHandle];
    //打開數(shù)據(jù)庫
    [dataBase openDB];
    //創(chuàng)建表
    [dataBase creatTable];
    //添加
    [dataBase insertName:@"小麗麗" gender:@"女" age:18];
    //更新
    [dataBase updateWithUID:2];
    //刪除
    [dataBase deleteWithUID:3];
    //關閉
    [dataBase closeDB];

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末尤慰,一起剝皮案震驚了整個濱河市拼缝,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖齿拂,帶你破解...
    沈念sama閱讀 210,978評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異敛瓷,居然都是意外死亡颜懊,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評論 2 384
  • 文/潘曉璐 我一進店門避诽,熙熙樓的掌柜王于貴愁眉苦臉地迎上來龟虎,“玉大人,你說我怎么就攤上這事茎用∏沧埽” “怎么了睬罗?”我有些...
    開封第一講書人閱讀 156,623評論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長旭斥。 經(jīng)常有香客問我容达,道長,這世上最難降的妖魔是什么垂券? 我笑而不...
    開封第一講書人閱讀 56,324評論 1 282
  • 正文 為了忘掉前任花盐,我火速辦了婚禮,結果婚禮上菇爪,老公的妹妹穿的比我還像新娘算芯。我一直安慰自己,他們只是感情好凳宙,可當我...
    茶點故事閱讀 65,390評論 5 384
  • 文/花漫 我一把揭開白布熙揍。 她就那樣靜靜地躺著,像睡著了一般氏涩。 火紅的嫁衣襯著肌膚如雪届囚。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,741評論 1 289
  • 那天是尖,我揣著相機與錄音意系,去河邊找鬼。 笑死饺汹,一個胖子當著我的面吹牛蛔添,可吹牛的內容都是我干的。 我是一名探鬼主播兜辞,決...
    沈念sama閱讀 38,892評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼迎瞧,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了弦疮?” 一聲冷哼從身側響起夹攒,我...
    開封第一講書人閱讀 37,655評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎胁塞,沒想到半個月后咏尝,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,104評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡啸罢,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年编检,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片扰才。...
    茶點故事閱讀 38,569評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡允懂,死狀恐怖,靈堂內的尸體忽然破棺而出衩匣,到底是詐尸還是另有隱情蕾总,我是刑警寧澤粥航,帶...
    沈念sama閱讀 34,254評論 4 328
  • 正文 年R本政府宣布,位于F島的核電站生百,受9級特大地震影響递雀,放射性物質發(fā)生泄漏。R本人自食惡果不足惜蚀浆,卻給世界環(huán)境...
    茶點故事閱讀 39,834評論 3 312
  • 文/蒙蒙 一缀程、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧市俊,春花似錦杨凑、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至据忘,卻和暖如春鹦牛,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背勇吊。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留窍仰,地道東北人汉规。 一個月前我還...
    沈念sama閱讀 46,260評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像驹吮,于是被迫代替她去往敵國和親针史。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,446評論 2 348

推薦閱讀更多精彩內容

  • 轉至元數(shù)據(jù)結尾創(chuàng)建: 董瀟偉碟狞,最新修改于: 十二月 23, 2016 轉至元數(shù)據(jù)起始第一章:isa和Class一....
    40c0490e5268閱讀 1,686評論 0 9
  • *面試心聲:其實這些題本人都沒怎么背,但是在上海 兩周半 面了大約10家 收到差不多3個offer,總結起來就是把...
    Dove_iOS閱讀 27,128評論 29 470
  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理啄枕,服務發(fā)現(xiàn),斷路器族沃,智...
    卡卡羅2017閱讀 134,628評論 18 139
  • iOS H5 PHP 數(shù)據(jù)庫管理系統(tǒng) SQL: SQL 是Structured Query Language(結構...
    云之君兮鵬閱讀 1,480評論 1 3
  • 文/芒果木木 雙雙從小到大的戀愛史用一張紙就可以表達完频祝。不是寫滿一張紙,是一張什么都沒有的白紙脆淹。 不過這上面很快就...
    吹泡泡的兔子閱讀 255評論 0 2