sqlite3

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sqlite3相关的知识,希望对你有一定的参考价值。

//

//  HRTZhongDuanBiao.m

//  merchant

//

//  Created by Deng Chaojie on 2017/6/8.

//  Copyright ? 2017 Hrtpayment. All rights reserved.

//

 

#import "HRTZhongDuanBiao.h"

#import <sqlite3.h>

 

#define KDBName @"ZhongDuan.sqlite"

#define KbiaoMing @"ZhongDuanBiao"

#define KzhongDuanHao @"zhongDuanHao"

#define KliuShuiHao @"liuShuiHao"

#define KpiCiHao @"piCiHao"

#define KchaXunHao @"chaXunHao"

 

 

@interface HRTZhongDuanBiao ()

 

@property (nonatomic) sqlite3 *sqlite;

@end

 

@implementation HRTZhongDuanBiao

 

static HRTZhongDuanBiao *biao = nil;

+ (HRTZhongDuanBiao *)share

{

    static dispatch_once_t t;

    

    dispatch_once(&t, ^{

        

        biao = [[HRTZhongDuanBiao alloc] init];

        if ([biao openDB]) {

            [biao chuangJianBiao];

        }

        

    });

    return biao;

}

 

- (BOOL)xieRuShuJu:(NSDictionary *)shuJu

{

    NSString *xieRuSql = [NSString stringWithFormat:@"INSERT INTO ‘%@‘ (‘%@‘,‘%@‘, ‘%@‘,‘%@‘) VALUES (‘%@‘,‘%@‘,‘%@‘,‘%@‘)",

                          KbiaoMing,KzhongDuanHao, KliuShuiHao, KpiCiHao, KchaXunHao,shuJu[@"zhongDuanHao"],shuJu[@"liuShuiHao"],shuJu[@"piCiHao"],shuJu[@"chaXunHao"]];

    return [self zhiXingSql:xieRuSql];

}

- (BOOL)gengXinShuJu:(NSDictionary *)shuJu

{

    NSString *gengXinSql = [NSString stringWithFormat:@"update %@ set %@ = ‘%@‘,%@ = ‘%@‘,%@ = ‘%@‘ where %@ = ‘%@‘",KbiaoMing,KliuShuiHao,shuJu[@"liuShuiHao"],KpiCiHao,shuJu[@"piCiHao"],KchaXunHao,shuJu[@"chaXunHao"],KzhongDuanHao,shuJu[@"zhongDuanHao"]];

    return [self zhiXingSql:gengXinSql];

}

- (NSArray *)duQuShuJuWithTid:(NSString *)tid

{

    NSMutableArray *mutableA = [[NSMutableArray alloc] init];

    if ([self openDB]) {

        NSString *sql = [NSString stringWithFormat:@"SELECT * FROM %@ where %@ = ‘%@‘",KbiaoMing,KzhongDuanHao,tid] ;

        if (tid.length == 0) {

            sql = [NSString stringWithFormat:@"SELECT * FROM %@",KbiaoMing] ;

        }

        sqlite3_stmt *statement;

        if (sqlite3_prepare_v2(_sqlite, [sql UTF8String], -1, &statement, nil) == SQLITE_OK)

        {

            

            while (sqlite3_step(statement) == SQLITE_ROW) {

                NSMutableDictionary *dic = [[NSMutableDictionary alloc] init];

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

                [dic setObject:dataid forKey:@"did"];

                

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

                [dic setObject:zhongDuanHao forKey:@"zhongDuanHao"];

                

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

                [dic setObject:liuShuiHao forKey:@"liuShuiHao"];

 

                NSString *piCiHao = [[NSString alloc] initWithUTF8String:(char*)sqlite3_column_text(statement, 3)];

                [dic setObject:piCiHao forKey:@"piCiHao"];

                

                NSString *chaXunHao = [[NSString alloc] initWithUTF8String:(char*)sqlite3_column_text(statement, 4)];

                [dic setObject:chaXunHao forKey:@"chaXunHao"];

                [mutableA addObject:dic];

            }

        }

        sqlite3_finalize(statement);

        sqlite3_close(_sqlite);

    }

    return mutableA;

}

 

- (BOOL)openDB

{

    NSArray *pathA = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);

    NSString *pathDocument = pathA[0];

    NSString *pathDB = [pathDocument stringByAppendingPathComponent:KDBName];

    int jieGuo = sqlite3_open([pathDB UTF8String], &_sqlite);

    if (jieGuo == SQLITE_OK) {

        return YES;

    }else

    {

        sqlite3_close(_sqlite);

    }

    HRTLog(@"openDB 失败");

    return NO;

}

- (void)chuangJianBiao

{

    NSString *sql = [NSString stringWithFormat:@"CREATE TABLE IF NOT EXISTS %@ (ID INTEGER PRIMARY KEY AUTOINCREMENT,%@ TEXT,%@ TEXT,%@ TEXT,%@ TEXT)",KbiaoMing,KzhongDuanHao,KliuShuiHao,KpiCiHao,KchaXunHao];

    if ([self zhiXingSql:sql]) {

        

    }else

    {

        HRTLog(@"创建表失败");

    }

}

- (BOOL)zhiXingSql:(NSString *)sql

{

    if ([self openDB]) {

        char *err;

        if (sqlite3_exec(_sqlite, [sql UTF8String], NULL, NULL, &err) != SQLITE_OK) {

            

            HRTLog(@"sqlite3_exec 失败");

            return NO;

        }else{

            return YES;

        }

    }

    sqlite3_close(_sqlite);

    HRTLog(@"zhiXingSql 失败");

    return NO;

}

@end

以上是关于sqlite3的主要内容,如果未能解决你的问题,请参考以下文章