嵌入式数据库

SQLite嵌入式数据库的优势

1.支持事件,你并不需要配置,无需安装,不需要管理员

2.支持部分脂肪SQL92

3.完整的数据库被存储在磁盘上的文件的顶部,相同的数据库文件可以在不同机器上面使用,最大支持数据库2T

4.整个系统少于3万行,少于250KB的内存占用

Linux系统级的SQLite技术实现框架libsqlite3.0.dylib

開始使用SQLite

1.引入<sqlite3.h>头文件

2.打开数据库

3.运行SQL命令

4.关闭数据库

一下代码展示整个数据库的 打开,关闭,添加,删除,查找,改动,

创建一个单例

#import <Foundation/Foundation.h>
@class Student;
@interface DataBaseHandle : NSObject
//创建一个单例
+(DataBaseHandle *)shareDB; //获取Documents路径
- (NSString *)documentsPath; //打开数据库
- (void)openDB; //关闭数据库
- (void)closeDB; //创建表
- (void)createTable; //插入信息
- (void)insertStudent:(Student *)stu; //改动信息
- (void)updateMessage; //删除信息
- (void)deleteMessage; //查找所有
- (void)selectAllStudent; //条件查找
- (void)selectWithSex:(NSString *)sex; @end
#import "DataBaseHandle.h"
#import <sqlite3.h>
#import "Student.h"
//全局单利对象
static DataBaseHandle *shareModle = nil;
@implementation DataBaseHandle
#pragma mark 实现单利
+ (DataBaseHandle *)shareDB
{
if (nil == shareModle)
{
shareModle = [[DataBaseHandle alloc] init];
}
return shareModle;
} #pragma mark 获取Documents路径
- (NSString *)documentsPath
{
NSString *documentPath = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)[0];
return documentPath;
} //在操作数据之前引入框架(sql...3.0)
//声明一个数据库的对象
static sqlite3 *db = nil;
#pragma mark 打开数据库
- (void)openDB
{
//推断数据库是不是为空
if (nil == db)
{
//与documents路径拼接数据库存放路径(获得存放路径)
NSString *dbPath = [[self documentsPath] stringByAppendingString:@"/Student.sqlite"];
//依据路径打开数据库,如该路径下没有数据库,就自己主动创建一个数据库
//打开数据库(c语言中的语法)
int result = sqlite3_open(dbPath.UTF8String, &db);
//推断是否打开数据库成功
if (result == SQLITE_OK)
{
NSLog(@"数据库打开成功");
}
else
{
NSLog(@"数据库打开失败");
}
}
} #pragma mark 关闭数据库 - (void)closeDB
{
int result = sqlite3_close(db);
if (result == SQLITE_OK)
{
//假设关闭成功,置为nill
db = nil;
NSLog(@"数据库关闭成功");
}
else
{
NSLog(@"数据库关闭失败");
}
} #pragma mark 创建表
- (void)createTable
{
//要创建表,就要使用SQL语句.
//SQL语句在这是以字符串的形式存在的
NSString *createString = @"CREATE TABLE IF NOT EXISTS student (sid INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL , sname TEXT, ssex TEXT, sage TEXT)";
//运行SQL语句
int result = sqlite3_exec(db, createString.UTF8String, NULL, NULL, NULL); if (result == SQLITE_OK)
{
NSLog(@"创建表成功");
}
else
{
NSLog(@"创建失败");
} } #pragma mark 插入信息
- (void)insertStudent:(Student *)stu
{
//准备插入语句
NSString *insertString = [NSString stringWithFormat:@"INSERT INTO student (sname,ssex,sage) VALUES ('%@','%@','%@')",stu.name,stu.sex,stu.age];
//运行语句
int result = sqlite3_exec(db, insertString.UTF8String, NULL, NULL, NULL);
if (result == SQLITE_OK)
{
NSLog(@"插入成功");
}
else
{
NSLog(@"插入失败");
} } #pragma mark 改动数据
- (void)updateMessage
{
//准备改动语句
NSString *undataString = @"UPDATE student SET ssex = '女' ,sname = '小梦' WHERE sid = 10";
int result = sqlite3_exec(db, undataString.UTF8String, NULL, NULL, NULL);
if (result == SQLITE_OK)
{
NSLog(@"改动成功");
}
else
{
NSLog(@"改动失败");
} } #pragma mark 删除数据
- (void)deleteMessage
{
//准备删除语句
NSString *deleteString = @"DELETE FROM student WHERE sid = 1";
int result = sqlite3_exec(db, deleteString.UTF8String, NULL, NULL, NULL);
if (result == SQLITE_OK)
{
NSLog(@"delete OK");
}
else
{
NSLog(@"delete _NO");
} } #pragma mark 查找所有
- (void)selectAllStudent
{
//准备查找语句
NSString *selectAll = @"SELECT *FROM student";
//创建伴随指针
sqlite3_stmt *stmt = nil; //预备运行
int result = sqlite3_prepare(db, selectAll.UTF8String, -1, &stmt, NULL);
if (result == SQLITE_OK)
{
//在没有查找完毕之前一直循环运行
while (sqlite3_step(stmt) == SQLITE_ROW)
{
//取出sid(第0列)
NSInteger sid = sqlite3_column_int(stmt, 0);
//取出sname(第1列)
NSString *sname = [NSString stringWithUTF8String:(const char *)sqlite3_column_text(stmt, 1)];
//取出ssex(第2列)
NSString *ssex = [NSString stringWithUTF8String:(const char *)sqlite3_column_text(stmt, 2)];
//取出sage(第3列)
NSString *sage = [NSString stringWithUTF8String:(const char *)sqlite3_column_text(stmt, 3)];
NSLog(@"sid:%d sname:%@ ssex:%@ sage:%@",sid,sname,ssex,sage); }
sqlite3_finalize(stmt);
}
else
{
//假设查找失败,结束伴随指针
sqlite3_finalize(stmt);
NSLog(@"查找失败");
} }
#pragma mark 条件查找
- (void)selectWithSex:(NSString *)sex
{
//准备查找语句
NSString *selecstString = @"SELECT * FROM student WHERE ssex = ? ";
//创建伴随指针
sqlite3_stmt *stmt = nil;
//预运行
int result = sqlite3_prepare(db, selecstString.UTF8String, -1, &stmt, NULL); if (result == SQLITE_OK)
{
//绑定?的值
//"1"代表第一个问号"? "和哪个參数绑定
sqlite3_bind_text(stmt, 1, sex.UTF8String, -1, NULL);
while (sqlite3_step(stmt) == SQLITE_ROW)
{ NSInteger sid = sqlite3_column_int(stmt, 0);
NSString *sname = [NSString stringWithUTF8String:(const char *)sqlite3_column_text(stmt, 1)];
NSString *ssex = [NSString stringWithUTF8String:(const char *)sqlite3_column_text(stmt, 2)];
NSString *sage = [NSString stringWithUTF8String:(const char *)sqlite3_column_text(stmt, 3)];
NSLog(@"sid: %d sname: %@ ssex: %@ sage: %@",sid,sname,ssex,sage); } }
else
{
//关闭指针
sqlite3_finalize(stmt);
NSLog(@"查询失败");
}
} @end

创建一个Student类

#import <Foundation/Foundation.h>

@interface Student : NSObject
@property(nonatomic,strong)NSString *name;
@property(nonatomic,strong)NSString *age;
@property(nonatomic,strong)NSString *sex;
@end

在 ViewController.m中 ViewDidLoad 调用方法

    //打印路径
NSLog(@"%@",[[DataBaseHandle shareDB] documentsPath]);
//打开数据库
[[DataBaseHandle shareDB] openDB];
//创建表
[[DataBaseHandle shareDB] createTable]; //插入信息
// Student *stu = [[Student alloc] init];
// stu.name = @"小露";
// stu.age = @"29";
// stu.sex = @"女";
// [[DataBaseHandle shareDB] insertStudent:stu];
//改动
// [[DataBaseHandle shareDB] updateMessage];
//删除
// [[DataBaseHandle shareDB] deleteMessage];
//查找所有信息
// [[DataBaseHandle shareDB] selectAllStudent];
//依据条件查找信息
[[DataBaseHandle shareDB] selectWithSex:@"女"];

版权声明:本文博主原创文章,博客,未经同意不得转载。

IOS 数据库管理系统(SQLite)的更多相关文章

  1. iOS数据处理之SQLite数据库

    1. 数据库管理系统 1> SQL语言概述 SQL: SQL是Structured Query Language(结构化查询语言)的缩写.SQL是专为数据库而建立的操作命令集, 是一种功能齐全的 ...

  2. iOS开发数据库篇—SQLite简单介绍

    iOS开发数据库篇—SQLite简单介绍 一.离线缓存 在项目开发中,通常都需要对数据进行离线缓存的处理,如新闻数据的离线缓存等. 说明:离线缓存一般都是把数据保存到项目的沙盒中.有以下几种方式 (1 ...

  3. iOS开发数据库篇—SQLite的应用

    iOS开发数据库篇—SQLite的应用 一.简单说明 在iOS中使用SQLite3,首先要添加库文件libsqlite3.dylib和导入主头文件. 导入头文件,可以使用库中的函数(是纯C语言的) 二 ...

  4. IOS开发数据库篇—SQLite模糊查询

    IOS开发数据库篇—SQLite模糊查询 一.示例 说明:本文简单示例了SQLite的模糊查询 1.新建一个继承自NSObject的模型 该类中的代码: // // YYPerson.h // 03- ...

  5. iOS开发数据库篇—SQLite常用的函数

    iOS开发数据库篇—SQLite常用的函数 一.简单说明 1.打开数据库 int sqlite3_open( const char *filename,   // 数据库的文件路径 sqlite3 * ...

  6. 【转】 iOS开发数据库篇—SQLite简单介绍

    开始学SQLite啦, 原文: http://www.cnblogs.com/wendingding/p/3868893.html iOS开发数据库篇—SQLite简单介绍 一.离线缓存 在项目开发中 ...

  7. iOS学习笔记(十五)——数据库操作(SQLite)

    SQLite (http://www.sqlite.org/docs.html) 是一个轻量级的关系数据库.SQLite最初的设计目标是用于嵌入式系统,它占用资源非常少,在嵌入式设备中,只需要几百K的 ...

  8. FMDB是iOS平台的SQLite数据库框架

    1.FMDB简介 什么是FMDBFMDB是iOS平台的SQLite数据库框架 FMDB以OC的方式封装了SQLite的C语言API 为什么使用FMDB使用起来更加面向对象,省去了很多麻烦.冗余的C语言 ...

  9. 【转】iOS学习笔记(十五)——数据库操作(SQLite)

    SQLite (http://www.sqlite.org/docs.html) 是一个轻量级的关系数据库.SQLite最初的设计目标是用于嵌入式系统,它占用资源非常少,在嵌入式设备中,只需要几百K的 ...

随机推荐

  1. POJ 2299 Ultra-QuickSort (求序列的逆序对数)

    题意:废话了一大堆就是要你去求一个序列冒泡排序所需的交换的次数. 思路:实际上是要你去求一个序列的逆序队数 看案例: 9 1 0 5 4 9后面比它小的的数有4个 1后面有1个 0后面没有 5后面1个 ...

  2. 采用keepalived施工可用性MySQL-HA

    描述了使用keepalived施工可用性MySQL-HA,两个保证MySQL数据一致性,然后,keepalived虚拟IP,经keepalived内置的在线监测功能来实现MySQL. AD: 关于My ...

  3. 期望dp专题

    一直不明白为什么概率是正推,期望是逆推. 现在题目做多了,慢慢好像有点明白了 poj2096 收集bug,  有n个种类的bug,和s个子系统.  每找到一个bug需要一天. 要我我们求找到n个种类的 ...

  4. 王立平--Program Files (x86)

    window7根据系统.program files(x86) 它是应用程序目录,在64下位系统.为了更好的相容性32位程序,在一些安装32位程序(请注意,有些节目自己是32位),将默认被安装progr ...

  5. ViewPager空指针错误,android.support.v4.view.ViewPager.onSaveInstanceState

    support.v4 包为我们提供了一个非常实用的滑动控件ViewPager,在使用ViewPager时有一个需要注意的地方: 即: android.support.v4.view.ViewPager ...

  6. poj 1959 Darts 同意反复组合

    水题.直接贴代码. //poj 1959 //sep9 #include <iostream> using namespace std; int n; int f[128]; int so ...

  7. 冒泡排序算法(Java)

     冒泡排序即每次遍历.相邻数字间进行比較,前者大于后者进行交换,不断将最大值后移,直至沉至最后位置:算法关键要点在于确定每次循环的边界. 后面两种算法则是对冒泡排序一定程度上的改良,但相对于其它排 ...

  8. zoj 3288 Domination (可能dp)

    ///dp[i][j][k]代表i行j列件,并把一k的概率 ///dp[i][j][k]一种常见的方法有四种传输 ///1:dp[i-1][j][k-1] 可能 (n-(i-1))*j/(n*m-(k ...

  9. MIPS台OpenWrt在系统内的路由器Rust应用程序开发

    笔者:Liigo(庄小莉) 迄今:2014年9一个月17日本 (9一个月29日更新,11一个月19日本再次更新.在最后可用更新) 原文链接:http://blog.csdn.net/liigo/art ...

  10. 特征选择(三)-K-L变换

    上一讲说到,各个特征(各个分量)对分类来说,其重要性当然是不同的. 舍去不重要的分量,这就是降维. 聚类变换觉得:重要的分量就是能让变换后类内距离小的分量. 类内距离小,意味着抱团抱得紧. 可是,抱团 ...