Sqlite -用戶信息UserDataManger

每次更新用戶數(shù)據(jù)用插入,在插入前刪除數(shù)據(jù),登出把數(shù)據(jù)刪了(登錄獲取用戶數(shù)據(jù))。

#import <Foundation/Foundation.h>
@interface UserModel : NSObject

///用戶ID
@property (nonatomic , assign) NSInteger identifie;

///姓名
@property (nonatomic , strong) NSString * name;

///性別
@property (nonatomic , strong) NSString * sex;

///年齡
@property (nonatomic , assign) NSInteger age;

///手機
@property (nonatomic , strong) NSString * mobile;

///頭像ID
@property (nonatomic , assign) NSInteger  image_id;

///頭像路徑
@property (nonatomic , strong) NSString * image_path;

@end

UserDataManger.h

#import "FMDB.h"
#import "UserModel.h"
@interface UserDataManger : NSObject

#pragma mark ----單例----
+(UserDataManger *)shareInstance;

#pragma mark ---打開數(shù)據(jù)庫---
-(void)openDB;

#pragma mark ---在數(shù)據(jù)庫中創(chuàng)建表---
-(void)createTableWithTableName;

#pragma mark ---添加數(shù)據(jù)---
-(void)insertUserData:(UserModel *)usermodel ;

#pragma mark ---查詢數(shù)據(jù)---
-(UserModel *)getUserInfor;
@end

UserDataManger.m


#import "UserDataManger.h"
static FMDatabase *db = nil;

@implementation UserDataManger

+(UserDataManger *)shareInstance
{
    static dispatch_once_t onceToken;
    static  UserDataManger * manger = nil;
    dispatch_once(&onceToken, ^{
        manger = [[UserDataManger alloc]init];
        [manger openDB];
        [manger createTableWithTableName];
    });
    return manger;
}

-(NSString *)createSqliteWithSqliteName
{
    return [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)firstObject]stringByAppendingPathComponent:@"user.sqlite"];
}

#pragma mark ---打開數(shù)據(jù)庫---
-(void)openDB
{
    if (db != nil) {
        return;
    }
    NSString *path = [self createSqliteWithSqliteName];
    NSLog(@"path ==== %@",path);
    db = [FMDatabase databaseWithPath:path];
    if ([db open]) {
        NSLog(@"數(shù)據(jù)庫打開成功");
    }
    else {
        NSLog(@"數(shù)據(jù)庫打開失敗");
    }
}

#pragma mark ---在數(shù)據(jù)庫中創(chuàng)建表---表名--user
-(void)createTableWithTableName
{
    [db open];
    NSString *string = [NSString stringWithFormat:@"create table if not exists user (ID integer primary key autoincrement, identifie integer, name text, sex text, age integer, mobile text, image_id integer, image_path text)"];
    BOOL flag = [db executeUpdate:string];
    NSLog(@"創(chuàng)建表flag ==== %d",flag);
}

#pragma mark ---添加數(shù)據(jù)---
-(void)insertUserData:(UserModel *)usermodel
{
    UserModel * model = usermodel;
    [db open];
    //這樣設計適合存?zhèn)€人數(shù)據(jù)
    NSInteger count =[[db stringForQuery:@"select count(*) from user"] integerValue];
    if (count > 0) {
        [db executeUpdate:@"DELETE FROM user WHERE 1=1"];
    }
    NSString *string = [NSString stringWithFormat:@"insert into user (identifie, name, sex, age, mobile, image_id, image_path) values (?, ?, ?, ?, ?, ?, ?)"];
    NSString *identifie = [NSString stringWithFormat:@"%ld",(long)model.identifie];
    NSString *age = [NSString stringWithFormat:@"%ld",(long)model.age];
    NSString *image_id = [NSString stringWithFormat:@"%ld",(long)model.image_id];
    BOOL flag = [db executeUpdate:string,identifie,model.name,model.sex,age,model.mobile,image_id,model.image_path];
    NSLog(@"插入數(shù)據(jù)flag ==== %d",flag);
    [db close];
}

#pragma mark ---查詢數(shù)據(jù)---
-(UserModel *)getUserInfor{
    UserModel  *model = [[UserModel alloc]init];
    [db open];
    NSString *string = [NSString stringWithFormat:@"select * from user"];
    FMResultSet *result = [db executeQuery:string];
    while ([result next]) {
        model.identifie  = [result intForColumn:@"identifie"];
        model.name       = [result stringForColumn:@"name"];
        model.sex        = [result stringForColumn:@"age"];
        model.age        = [result intForColumn:@"age"];
        model.mobile     = [result stringForColumn:@"mobile"];
        model.image_id   = [result intForColumn:@"image_id"];
        model.image_path = [result stringForColumn:@"image_path"];
    }
    [db close];
    return  model;
}

@end

vc

- (IBAction)addUserInfor:(UIButton *)sender {
    UserModel * model = [[UserModel alloc]init];
    model.identifie = 1111;
    model.name = @"劉哥哥";
    model.sex = @"男";
    model.age = 23;
    model.mobile = @"13612345678";
    model.image_id = 123;
    model.image_path = @"http://ww2.sinaimg.cn/mw690/95a6ddc2gw1f9pl2eeycpj20j60l7mz7.jpg";
    [[UserDataManger shareInstance]insertUserData:model];;
}
- (IBAction)search:(UIButton *)sender {
    UserModel * model = [[UserDataManger shareInstance]getUserInfor];
    NSLog(@"%@",model.name);
}
最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,835評論 6 534
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,676評論 3 419
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,730評論 0 380
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,118評論 1 314
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,873評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,266評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,330評論 3 443
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,482評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,036評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 40,846評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,025評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,575評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,279評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,684評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,953評論 1 289
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,751評論 3 394
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,016評論 2 375

推薦閱讀更多精彩內(nèi)容