SQLite(增盾剩、刪雷激、改替蔬、查 )以及第三方框架FMDB的基本使用

首先關(guān)于數(shù)據(jù)庫,工作中我們可能會接觸過很多,像公司常用甲骨文公司的Oracle數(shù)據(jù)庫,特點是安全可靠,適合需要存儲大量數(shù)據(jù)的大公司使用,相比Oracle,微軟公司的SQL Server適合中小公司使用,同樣安全可靠(一般都是VS + SQL Server配合使用),還有MySQL、DB2屎暇、甚至Access等等,但以上介紹的大多都適合PC端使用;而對于移動端iOS承桥、Android來說,非你莫屬的要屬于SQLite,首先SQLite是一款輕型的嵌入式數(shù)據(jù)庫,同時SQLite同Oracle,SQL Server一樣同屬于關(guān)系型數(shù)據(jù)庫,并且它占用的資源非常小,所以非常適合移動客戶端和嵌入式設(shè)備所需數(shù)據(jù)庫的特點.
  • 說到SQLite數(shù)據(jù)庫,我們不得不提得就是數(shù)據(jù)庫管理軟件Navicat,Navicat是一套快速、可靠的數(shù)據(jù)庫管理工具,且Navicat專為簡化數(shù)據(jù)庫的管理及降低系統(tǒng)管理成本而設(shè)計的,并且Navicat Premium是一個可多重連接的數(shù)據(jù)庫管理工具根悼,它可讓你以單一程序同時連接到MySQL凶异、Oracle、PostgreSQL番挺、SQLite 及 SQL Server數(shù)據(jù)庫唠帝,讓管理不同類型的數(shù)據(jù)庫更加方便屯掖。**

  • 雖然Navicat提供了簡單的界面化操作功能,但是工作中,我們?yōu)榱诵屎凸ぷ鲗嶋H需要,我們更多適合其實使用的是SQL語句,也就是結(jié)構(gòu)化查詢語言.**

以上扯了那么多,數(shù)據(jù)庫存在的意義無非是存儲數(shù)據(jù),而我們對數(shù)據(jù)的操作,無非也就是最關(guān)鍵的四個字:增刪改查.
首先關(guān)于SQL語句常用的關(guān)鍵字

**
select玄柏、insert、update贴铜、delete粪摘、from、create绍坝、where徘意、desc、order轩褐、by椎咧、group、table把介、alter勤讽、view、index等等,切記數(shù)據(jù)庫中不可以使用關(guān)鍵字來命名表拗踢、字段等操作
**

字段類型的說明
相比其他數(shù)據(jù)庫,SQLite數(shù)據(jù)庫的數(shù)據(jù)類型僅僅就四種:

integer : 整型值

real : 浮點值

text : 文本字符串

blob : 二進制數(shù)據(jù)(比如文件)

SQL語句簡單的可以分為以下三類
數(shù)據(jù)定義語句(DDL:Data Definition Language)

** 包括create和drop等操作(通常用來創(chuàng)建表或者刪除表)**

數(shù)據(jù)操作語句(DML:Data Manipulation Language)

** 包括insert脚牍、update、delete等操作(添加巢墅、修改诸狭、刪除表中的數(shù)據(jù))**

數(shù)據(jù)查詢語句(DQL:Data Query Language)

** 可以用于查詢獲得表中的數(shù)據(jù) 關(guān)鍵字select(通常用來查詢表數(shù)據(jù))以及where(添加條件),order by(排序)君纫,group by(分組)和having(通常是在一個 SQL 句子的最后)**

SQLite數(shù)據(jù)庫的基本操作
表的約束

** 工作中,為了符合我們?nèi)粘2僮饕约傲鞒痰囊?guī)范,常常創(chuàng)建表的時候我們需要考慮多方面的因素,比如有些代表特別意義的字段不能為空(姓名,性別等...),有些字段必須為一(身份證),這個時候就需要我們給字段設(shè)置嚴(yán)格的約束,讓其從創(chuàng)建數(shù)據(jù)庫表的時候就把一些不規(guī)范的數(shù)據(jù)給排除掉,以保證數(shù)據(jù)的規(guī)范性. **

關(guān)健字:

Not Null :規(guī)定字段的值不能為NULL

Unique :規(guī)定字段的值必須唯一

Default :指定字段的默認(rèn)值

//NAME字段不能為NULL驯遇,并且唯一age字段不能為NULL,并且默認(rèn)為1
CREATE TABLE t_test (ID INTEGER, NAME TEXT NOT NULL UNIQUE, AGE INTEGER NOT NULL DEFAULE 1);

主鍵約束

** 為了更方便的管理數(shù)據(jù),保證數(shù)據(jù)的規(guī)范性,數(shù)據(jù)庫設(shè)計之初應(yīng)該多考慮數(shù)據(jù)的唯一性,因此再創(chuàng)建表的時候,我們有必要給表添加一個主鍵,來約束表中的數(shù)據(jù),當(dāng)然如果設(shè)計的數(shù)據(jù)邏輯關(guān)聯(lián)性比較復(fù)雜的時候我們也可以指定多個字段來充當(dāng)我們表的主鍵(聯(lián)合主鍵) **

** 在創(chuàng)表的時候用PRIMARY KEY聲明一個主鍵 **

//ID作為t_test表的主鍵,并且設(shè)置為自增長
CREATE TABLE t_test (ID INTEGER PRIMARY KEY AUTOINCREMENT,NAME TEXT,AGE INTEGER);

外鍵

** 主要使用來約束表與表之間的關(guān)系,比如某個表中得一個字段是另一個表中得主鍵,這個時候我們就需要用到外鍵了 **

創(chuàng)建表(CREATE)
 格式:
 CREATE TABLE IF NOT EXISTS 表名 (字段名1 字段1類型,字段名2,字段2類型,...);
 示例:
 CREATE TABLE IF NOT EXISTS t_test (ID INTEGER,NAME TEXT,AGE INTEGER);
 
刪除表(DROP)
 格式:
 DROP TABLE IF EXISTS 表名;
 示例:
 DROP TABLE IF EXISTS t_test;
 
插入數(shù)據(jù)(INSERT)
格式:
INSERT INTO 表名 (字段名1,字段名2,...)VALUES (字段1的值,字段2的值,...);
示例:
INSERT INTO t_test (ID,NAME,AGE)VALUES (1,'J_mailbox',23);

更新數(shù)據(jù)(UPDATE)
格式:
UPDATE 表名 SET 字段名1=字段1的值,字段名2=字段名2的值,...;
示例:
UPDATE t_test SET ID=2,NAME='J_mailbox',AGE=25;

刪除數(shù)據(jù)(DELETE)
格式:
DELETE FROM 表名;
示例:
DELETE FROM t_test;

查詢語句
格式:
SELECT * FROM 表名;
SELECT NAME,AGE FROM 表名;
示例:
SELECT * FROM t_test;
SELECT NAME,AGE FROM t_test;

條件語句
格式:
//查詢表中字段等于某個值的所有記錄
SELECT * FROM 表名 WHERE 字段 = 某個值;

//查詢表中字段不等于某個值的所有記錄
SELECT * FROM 表名 WHERE 字段 != 某個值

//查詢表中字段是某個值的所有記錄
SELECT * FROM 表名 WHERE 字段 IS 某個值

//查詢表中字段不是某個值的所有記錄
SELECT * FROM 表名 WHERE 字段 IS NOT 某個值

//查詢表中字段大于某個值的所有記錄
SELECT * FROM 表名 WHERE 字段 > 某個值

//查詢表中字段小于某個值的所有記錄
SELECT * FROM 表名 WHERE 字段 < 某個值

//查詢表中某個字段依某個值開頭的所有記錄
SELECT * FROM 表名 WHERE 字段 LIKE "某個值%"

//查詢表中某個字段包含某個值的所有記錄
SELECT * FROM 表名 WHERE 字段 LIKE "%某個值%"

//查詢表中記錄從多少行開始,查詢多少行記錄
SELECT * FROM 表名 LIMIT 從多少行開始,查詢多少行;

//查詢表中字段名1等于某個值并且字段名2大于某個值的所有記錄(兩個條件都要滿足)
SELECT * FROM 表名 WHERE 字段名1 = 某個值 AND 字段名2 >某個值

//查詢表中字段名1等于某個值或者字段名2小于某個值的所有記錄(兩個條件滿足一個就可以)
SELECT * FROM 表名 WHERE 字段名1 = 某個值 OR 字段名2 <某個值

//更新表中字段等于某個值并且字段大于某個值的所有記錄
UPDATE 表名 SET 字段名1= WHERE 字段名2=某個值 AND 字段名3 >某個值;
//刪除t_test表中NAME等于J_mailbox或者AGE小于18的所有記錄
DELETE FROM 表名 WHERE 字段名1=某個值 OR 字段名2 <某個值;


示例:
//查詢t_test表中NAME字段等于J_mailbox的所有記錄
SELECT * FROM t_test WHERE NAME ='J_mailbox';

//查詢t_test表中NAME字段不等于J_mailbox的所有記錄
SELECT * FROM t_test WHERE NAME !='J_mailbox';

//查詢t_test表中NAME字段是J_mailbox的所有記錄
SELECT * FROM t_test WHERE NAME IS 'J_mailbox';

//查詢t_test表中NAME字段不是J_mailbox的所有記錄
SELECT * FROM t_test WHERE NAME IS NOT 'J_mailbox';

//查詢t_test表中AGE字段大于20的所有記錄
SELECT * FROM t_test WHERE AGE > 20;

//查詢t_test表中AGE字段大于20的所有記錄
SELECT * FROM t_test WHERE AGE < 20;

//查詢t_test中NAME依J字母開頭的所有記錄
SELECT * FROM 表名 WHERE NAME LIKE "J%"

//查詢t_test中NAME包含_mail的所有記錄
SELECT * FROM 表名 WHERE NAME LIKE "%_mail%"

//查詢表中記錄從0行開始,查詢10行記錄
SELECT * FROM 表名 LIMIT 0,10;

//查詢t_test表中NAME等于J_mailbox并且AGE字段大于20的所有記錄(兩個條件都要滿足)
SELECT * FROM t_test WHERE NAME ='J_mailbox' AND AGE > 20;

//查詢t_test表中NAME等于J_mailbox或者AGE字段小于20的所有記錄(兩個條件滿足一個就可以)
SELECT * FROM t_test WHERE NAME ='J_mailbox' OR AGE < 20;

//更新t_test表中NAME等于J_mailbox并且AGE大于18的所有記錄
UPDATE t_test SET AGE=20 WHERE NAME='J_mailbox' AND AGE >18;

//刪除t_test表中NAME等于J_mailbox或者AGE小于18的所有記錄
DELETE FROM t_test WHERE NAME='J_mailbox' OR AGE <18;



起別名(AS)
格式:
SELECT 字段名1 別名1 ,字段名2 別名2,... FROM 表名;
SELECT 字段名1 AS 別名1 ,字段名2 AS 別名2,... FROM 表名;

示例:
SELECT NAME 姓名 ,AGE 年齡 FROM t_test;
SELECT NAME AS 姓名,AGE AS 年齡 FROM t_test;

排序(ORDER BY, ASC,DESC)
格式:
SELECT * FROM 表名 ORDER BY 字段名;
SELECT * FROM 表名 ORDER BY 字段名 DESC;
SELECT * FROM 表名 ORDER BY 字段名1 ASC,字段名2 DESC;

示例:
SELECT * FFROM t_test ORDER BY AGE;
SELECT * FFROM t_test ORDER BY AGE DESC;
SELECT * FROM t_test ORDER BY 字段名1 ASC,字段名2 DESC;
計算記錄的總數(shù)量(COUNT)
格式:
SELECT COUNT(*) FROM 表名;
SELECT COUNT(字段) FROM 表名;

示例:
SELECT COUNT(*) FROM t_test;
SELECT COUNT(AGE) FROM t_test;

SQLite常用函數(shù)

** 打開數(shù)據(jù)庫 **

int sqlite3_open(

    const char *filename,   // 數(shù)據(jù)庫的文件路徑

    sqlite3 **ppDb          // 數(shù)據(jù)庫實例

);

** 執(zhí)行SQL語句 **

int sqlite3_exec(

    sqlite3*,                                  // 一個打開的數(shù)據(jù)庫實例

    const char *sql,                           // 需要執(zhí)行的SQL語句

    int (*callback)(void*,int,char**,char**),  // SQL語句執(zhí)行完畢后的回調(diào)

    void *,                                    // 回調(diào)函數(shù)的第1個參數(shù)

    char **errmsg                              // 錯誤信息

);
Objective-C對SQLite數(shù)據(jù)庫的增刪改查操作
  • 要使用SQLite,首先我們要導(dǎo)入SQLite3框架
#import "ViewController.h"
#import <sqlite3.h>

@interface ViewController ()
@property (nonatomic,assign)sqlite3 *db;
@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    //連接數(shù)據(jù)庫
    [self connectionDB];
}

//連接數(shù)據(jù)庫
- (void)connectionDB{
    NSLog(@"%@",NSHomeDirectory());
    //獲取路徑
    NSString *path=[[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject]stringByAppendingPathComponent:@"data.sqlite"];
    //判斷數(shù)據(jù)庫是否打開成功
    int success=sqlite3_open(path.UTF8String, &_db);
    //如果數(shù)據(jù)庫打開成功
    if (success==SQLITE_OK) {
        //創(chuàng)建表SQL語句,并且設(shè)置ID為主鍵,且自動增長
        NSString *sql=@"CREATE TABLE IF NOT EXISTS t_test (ID INTEGER PRIMARY KEY AUTOINCREMENT,NAME TEXT,AGE INTEGER)";
        //判斷創(chuàng)建表是否成功
        int success_t=sqlite3_exec(_db, sql.UTF8String, NULL, NULL, NULL);
        //如果創(chuàng)建表成功
        if (success_t==SQLITE_OK) {
            NSLog(@"創(chuàng)建表成功!");
        }else{
            NSLog(@"創(chuàng)建表失敗");
        }
    }else{
        NSLog(@"數(shù)據(jù)庫創(chuàng)建失敗");
    }
    //關(guān)閉數(shù)據(jù)庫
    //sqlite3_close(_db);
}

//增加數(shù)據(jù)
- (IBAction)addClick:(id)sender {
    
    //往表中循環(huán)插入100條數(shù)據(jù)
    for (int i = 0; i < 100 ; i++) {
        //名稱設(shè)置為J_mailbox
        NSString *name = [NSString stringWithFormat:@"J_mailbox-%d",i];
        //隨機生成20歲~25歲之間的記錄
        NSInteger age = arc4random_uniform(5) + 20;
        
        //sql插入語句的拼接
        NSString *resultStr = [NSString stringWithFormat:@"INSERT INTO t_test (NAME,AGE) VALUES('%@',%zd) ",name,age];
        //執(zhí)行sql插入語句
        int success =  sqlite3_exec(_db, resultStr.UTF8String, NULL, NULL, NULL);
        //判斷是否插入成功
        if (success == SQLITE_OK) {
            NSLog(@"添加數(shù)據(jù)成功!");
        }else{
            NSLog(@"添加數(shù)據(jù)失敗!");
        }
        
    }

}

//刪除數(shù)據(jù)
- (IBAction)deleteClick:(id)sender {
    
    //sql刪除語句
    NSString *sqlStr = @"DELETE FROM t_test WHERE AGE > 22 ;";
    //執(zhí)行刪除語句操作
    int success =  sqlite3_exec(_db, sqlStr.UTF8String, NULL, NULL, NULL);
    
    if (success == SQLITE_OK) {
        NSLog(@"刪除數(shù)據(jù)成功!");
    }else{
        NSLog(@"刪除數(shù)據(jù)失敗!");
    }

}

//修改數(shù)據(jù)數(shù)據(jù)
- (IBAction)updateClick:(id)sender {
    
    //sql修改語句
    NSString *sqlStr = @"UPDATE t_test SET AGE = 30 WHERE AGE <25;";
    //執(zhí)行修改語句操作
    int success =  sqlite3_exec(_db, sqlStr.UTF8String, NULL, NULL, NULL);
    
    if (success == SQLITE_OK) {
        NSLog(@"修改數(shù)據(jù)成功!");
    }else{
        NSLog(@"修改數(shù)據(jù)失敗!");
    }
}

//查詢數(shù)據(jù)
- (IBAction)selectClick:(id)sender {
    
    //sql查詢語句
    NSString *sqlStr = @"SELECT NAME,AGE FROM t_test WHERE AGE = 30;";
    //定義存放結(jié)果數(shù)據(jù)stmt
    sqlite3_stmt *stmt = NULL;
    //取一條記錄
    int success = sqlite3_prepare_v2(_db, sqlStr.UTF8String,-1, &stmt, NULL);
    if (success == SQLITE_OK) {
        NSLog(@"查詢數(shù)據(jù)成功!");
        //拿數(shù)據(jù) step 一步 拿一條記錄
        while (sqlite3_step(stmt) == SQLITE_ROW) { //證明取到了一條記錄
            //查詢到得NAME
            const char *name = (const char *)sqlite3_column_text(stmt, 0);
            //查詢到得AGE
            int age = sqlite3_column_int(stmt, 1);
            //打印結(jié)果
            NSLog(@"NAME = %@ AGE = %d",[NSString stringWithUTF8String:name],age);
        }
        
    }else{
        NSLog(@"查詢數(shù)據(jù)失敗!");
    }
}

FMDB的使用
  • 因為自帶的SQLite3 是基于C語言的API,所以使用的時候有些繁瑣,而FMDB是面向?qū)ο蟮?使用起來更加的簡單,且只需要調(diào)用對應(yīng)的方法,傳值進去即可,而且還提供了多線程安全
FMDB下載地址:https://github.com/ccgus/fmdb
示例:

#import "ViewController.h"
#import <sqlite3.h>
#import "FMDB.h"
@interface ViewController ()
@property (nonatomic, strong) FMDatabase *db;
@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    
    //連接數(shù)據(jù)庫
    [self connectionDB];
}

//連接數(shù)據(jù)庫
- (void)connectionDB{
    
    //創(chuàng)建數(shù)據(jù)庫路徑
    NSString *path  = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)lastObject]stringByAppendingPathComponent:@"data.sqlite"];
    FMDatabase *db = [FMDatabase databaseWithPath:path];
    self.db = db;
    BOOL success = [db open];
    if (success) { //打開成功
        NSLog(@"數(shù)據(jù)庫創(chuàng)建成功!");
        //創(chuàng)建表  執(zhí)行一條sql語句  增刪改 都是這樣的  查詢比較特殊
        NSString *sqlStr = @"CREATE TABLE IF NOT EXISTS t_test (ID INTEGER PRIMARY KEY AUTOINCREMENT ,NAME TEXT ,AGE INTEGER );";
        BOOL successT = [self.db executeUpdate:sqlStr];
        
        if (successT) {
            NSLog(@"創(chuàng)建表成功!");
        }else{
            NSLog(@"創(chuàng)建表失敗!");
        }
        
        
    }else{
        NSLog(@"數(shù)據(jù)庫創(chuàng)建失敗!");
    }
    
    NSLog(@"%@",NSHomeDirectory());
    
    //關(guān)閉數(shù)據(jù)庫
    //sqlite3_close(_db);
}

//增加數(shù)據(jù)
- (IBAction)addClick:(id)sender {
    
    //往表中循環(huán)插入100條數(shù)據(jù)
    for (int i = 0; i < 100 ; i++) {
        //名稱設(shè)置為J_mailbox
        NSString *name = [NSString stringWithFormat:@"J_mailbox-%d",i];
        //隨機生成20歲~25歲之間的記錄
        NSInteger age = arc4random_uniform(5) + 20;
        
        //sql插入語句的拼接
        NSString *resultStr = [NSString stringWithFormat:@"INSERT INTO t_test (NAME,AGE) VALUES('%@',%zd) ",name,age];

        //執(zhí)行sql插入語句(調(diào)用FMDB對象方法)
        BOOL success = [self.db executeUpdate:resultStr];
        //判斷是否添加成功
        if (success) {
            NSLog(@"添加數(shù)據(jù)成功!");
        }else{
            NSLog(@"添加數(shù)據(jù)失敗!");
        }
        
    }
    
    
}

//刪除數(shù)據(jù)
- (IBAction)deleteClick:(id)sender {

    //刪除語句
    NSString *sqlStr = @"DELETE FROM t_test WHERE AGE > 22 ;";
    //執(zhí)行sql刪除語句(調(diào)用FMDB對象方法)
    BOOL success = [self.db executeUpdate:sqlStr];
    
    if (success) {
        NSLog(@"刪除數(shù)據(jù)成功!");
    }else{
        NSLog(@"刪除數(shù)據(jù)失敗!");
    }
}

//修改數(shù)據(jù)
- (IBAction)updateClick:(id)sender {
    
    //修改語句
    NSString *sqlStr = @"UPDATE t_test SET AGE = 30 WHERE AGE <25;";
    //執(zhí)行sql修改語句(調(diào)用FMDB對象方法)
    BOOL success = [self.db executeUpdate:sqlStr];
    
    if (success) {
        NSLog(@"修改數(shù)據(jù)成功!");
    }else{
        NSLog(@"修改數(shù)據(jù)失敗!");
    }
    
}

//查詢數(shù)據(jù)
- (IBAction)selectClick:(id)sender {

    //查詢語句
    NSString *sqlStr = @"SELECT NAME,AGE FROM t_test WHERE AGE = 30;";
    
    //執(zhí)行sql查詢語句(調(diào)用FMDB對象方法)
    FMResultSet *set =  [self.db executeQuery:sqlStr];
    
    while ([set next]) { //等價于 == sqlite_Row
        //NAME
        NSString *name = [set stringForColumnIndex:0];
        //AGE
        NSInteger age = [set intForColumnIndex:1];
        
        NSLog(@"NAME = %@ AGE = %ld",name,(long)age);
    }
      
}


@end

以上Demo下載地址:https://github.com/chengaojian

以上就是關(guān)于SQLite的基本基本使用,由于比較簡單,所以以上SQL執(zhí)行結(jié)果就不一一截圖了,如果想學(xué)習(xí)者可以下載Navicat測試,如果對Oracle或者SQL Server感興趣,可以訪問我較早之前的博客:http://www.cnblogs.com/chengaojian/archive/2013/05/28/www-cnblogs-com-chengaojian-oracle-com.html(Oracle 入門基礎(chǔ),Oracle常用Sql語句)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蓄髓,一起剝皮案震驚了整個濱河市叉庐,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌双吆,老刑警劉巖眨唬,帶你破解...
    沈念sama閱讀 216,402評論 6 499
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件会前,死亡現(xiàn)場離奇詭異,居然都是意外死亡匾竿,警方通過查閱死者的電腦和手機瓦宜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,377評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來岭妖,“玉大人临庇,你說我怎么就攤上這事£腔牛” “怎么了假夺?”我有些...
    開封第一講書人閱讀 162,483評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長斋攀。 經(jīng)常有香客問我已卷,道長,這世上最難降的妖魔是什么淳蔼? 我笑而不...
    開封第一講書人閱讀 58,165評論 1 292
  • 正文 為了忘掉前任侧蘸,我火速辦了婚禮,結(jié)果婚禮上鹉梨,老公的妹妹穿的比我還像新娘讳癌。我一直安慰自己,他們只是感情好存皂,可當(dāng)我...
    茶點故事閱讀 67,176評論 6 388
  • 文/花漫 我一把揭開白布晌坤。 她就那樣靜靜地躺著,像睡著了一般旦袋。 火紅的嫁衣襯著肌膚如雪骤菠。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,146評論 1 297
  • 那天猜憎,我揣著相機與錄音娩怎,去河邊找鬼。 笑死胰柑,一個胖子當(dāng)著我的面吹牛截亦,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播柬讨,決...
    沈念sama閱讀 40,032評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼崩瓤,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了踩官?” 一聲冷哼從身側(cè)響起却桶,我...
    開封第一講書人閱讀 38,896評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后颖系,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體嗅剖,經(jīng)...
    沈念sama閱讀 45,311評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,536評論 2 332
  • 正文 我和宋清朗相戀三年嘁扼,在試婚紗的時候發(fā)現(xiàn)自己被綠了信粮。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,696評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡趁啸,死狀恐怖强缘,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情不傅,我是刑警寧澤旅掂,帶...
    沈念sama閱讀 35,413評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站访娶,受9級特大地震影響商虐,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜震肮,卻給世界環(huán)境...
    茶點故事閱讀 41,008評論 3 325
  • 文/蒙蒙 一称龙、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧戳晌,春花似錦、人聲如沸痴柔。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽咳蔚。三九已至豪嚎,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間谈火,已是汗流浹背侈询。 一陣腳步聲響...
    開封第一講書人閱讀 32,815評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留糯耍,地道東北人扔字。 一個月前我還...
    沈念sama閱讀 47,698評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像温技,于是被迫代替她去往敵國和親革为。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,592評論 2 353

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