IOS开发-UI学习-sqlite数据库的操作
IOS开发-UI学习-sqlite数据库的操作
sqlite是一个轻量级的数据库,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了,而且它的处理速度比Mysql、PostgreSQL这两款著名的数据库都还快,在ios和安卓app中常用来完成对数据进行离线缓存的处理,如新闻数据的离线缓存。
它的基本操作步骤是:
1、先加入sqlite开发库libsqlite3.dylib,
2、新建或打开数据库,
3、创建数据表,
4、插入数据,
5、查询数据并打印,
6、关闭数据库,
具体操作步骤如下:
1、导入sqlite数据库所需头文件:
导入完成后如图所示:

2、程序代码的编制:
//
// ViewController.m
// sqlite手动创建数据库和表
//
// Created by mac on 16/4/12.
// Copyright © 2016年 mzw. All rights reserved.
// #import "ViewController.h"
#import "FMDatabase.h"
@interface ViewController (){
FMDatabase *mydb;
NSString * idd;
NSString * age;
NSString * name;
} @end @implementation ViewController - (void)viewDidLoad {
[super viewDidLoad]; // 创建一个数据库路径path
NSString *path =[NSHomeDirectory() stringByAppendingString:@"/Documents/mydb.sqlite"]; // 根据创建好的路径path生成数据库
mydb = [[FMDatabase alloc]initWithPath:path]; // 创建一个在数据库中创建表mytable的字符串
NSString *tablecreate = @"create table if not exists mytable(id txt primary key,name text,age text)"; // 打开数据库
if ([mydb open]) { // 使用创建好的字符串新建表mytable
BOOL createOK = [mydb executeUpdate:tablecreate]; if (createOK) {
// 如果创建成果,打印创建成功的提示
NSLog(@"数据库创建成功"); // 使用sql语句中的insert into语句往创建好的mytable中添加一条记录
BOOL insertOK = [mydb executeUpdate:@"insert into mytable(id,age,name) values(?,?,?)",@"",@"",@"huangweiqiang"]; // 使用sql语句中的insert into语句往创建好的mytable中添加多条记录
BOOL insertsOK = [mydb executeUpdate:@"insert into mytable(id,age,name) select '2','24','mazhongwei' union all select '3','21','xiangyiyao' union all select '4','34','zhanglong'"]; // 使用sql语句中的delete from语句删除符合条件的语句
[mydb executeUpdate:@"delete from mytable where id = '4'"]; // 使用sql语句中的update更新表中的记录
[mydb executeUpdate:@"update mytable set age = '100000' where id = '3'"]; // 使用sql语句中的查询语句查询符合条件的语句,返回结果为一个集合,使用next函数遍历结果并赋值给idd,age,name三个变量
FMResultSet *rsset = [mydb executeQuery:@"select * from mytable where id = '3'"];
while ([rsset next]) {
idd = [rsset stringForColumn:@"id"];
age = [rsset stringForColumn:@"age"];
name = [rsset stringForColumn:@"name"];
} // 操作完成后关闭数据库
[mydb close]; // 打印查询结果
NSLog(@"%@_%@_%@",idd,age,name); }else{
// 如果创建失败,返回失败提示
NSLog(@"数据库创建失败");
}
} } @end
IOS开发-UI学习-sqlite数据库的操作的更多相关文章
- 从C#到Objective-C,循序渐进学习苹果开发(7)--使用FMDB对Sqlite数据库进行操作
本随笔系列主要介绍从一个Windows平台从事C#开发到Mac平台苹果开发的一系列感想和体验历程,本系列文章是在起步阶段逐步积累的,希望带给大家更好,更真实的转换历程体验.本篇主要开始介绍基于XCod ...
- 使用iOS原生sqlite3框架对sqlite数据库进行操作
摘要: iOS中sqlite3框架可以很好的对sqlite数据库进行支持,通过面向对象的封装,可以更易于开发者使用. 使用iOS原生sqlite3框架对sqlite数据库进行操作 一.引言 sqlit ...
- iOS开发UI篇—Quartz2D使用(矩阵操作)
iOS开发UI篇—Quartz2D使用(矩阵操作) 一.关于矩阵操作 1.画一个四边形 通过设置两个端点(长和宽)来完成一个四边形的绘制. 代码: - (void)drawRect:(CGRect)r ...
- 关于iOS开发的学习
关于iOS开发的学习,打个比方就像把汽车分解: 最底层的原料有塑料,钢铁 再用这些底层的东西造出来发动机,座椅 最后再加上写螺丝,胶水等,把汽车就拼起来了 iOS基本都是英文的资料, ...
- iOS开发 数据缓存-数据库
iOS中数据存储方式 Plist(NSArray\NSDictionary) Preference(偏好设置\NSUserDefaults) NSCoding (NSKeyedArchiver\NSk ...
- iOS开发UI篇—CAlayer(自定义layer)
iOS开发UI篇—CAlayer(自定义layer) 一.第一种方式 1.简单说明 以前想要在view中画东西,需要自定义view,创建一个类与之关联,让这个类继承自UIView,然后重写它的Draw ...
- iOS开发UI篇—CALayer简介
iOS开发UI篇—CALayer简介 一.简单介绍 在iOS中,你能看得见摸得着的东西基本上都是UIView,比如一个按钮.一个文本标签.一个文本输入框.一个图标等等,这些都是UIView. 其实 ...
- iOS开发UI篇—核心动画(UIView封装动画)
iOS开发UI篇—核心动画(UIView封装动画) 一.UIView动画(首尾) 1.简单说明 UIKit直接将动画集成到UIView类中,当内部的一些属性发生改变时,UIView将为这些改变提供动画 ...
- iOS开发UI篇—核心动画简介
转自:http://www.cnblogs.com/wendingding/p/3801036.html iOS开发UI篇—核心动画简介 一.简单介绍 Core Animation,中文翻译为核心动画 ...
随机推荐
- cocos2d-x 3.x 触摸事件
HelloWorldScene.h bool touchBegan(cocos2d::Touch*touch, cocos2d::Event*event);//触摸开始,返回bool类型 void t ...
- kill -QUIT <pid>
On Solaris and Linux a thread dump is also printed if the J2SE process receives a QUIT signal. So ki ...
- SystemClock.sleep和Thread.sleep的区别
在Java中我们处理线程同步问题时,处理延迟可能会使用Thread类的sleep方法,这里抛开concurrent类的一些方法,其实 Android平台还提供了一个SystemClock.sleep方 ...
- div使用
div style常用属性 一.常用属性: 1.Height:设置DIV的高度. 2.Width:设置DIV的宽度. 例: <div style="width:200px;height ...
- iOS启动屏 ➕ 闪屏的方法
转载自:http://www.starming.com/index.php?v=index&view=21 在- (BOOL)application:(UIApplication *)appl ...
- Web安全检测工具的使用.
Nikto2 Nikto2是一款使用perl语言写的多平台扫描软件,是一款命令行模式的工具,它可以扫描指定主机的WEB类型 主机名.特定目录.Cookie.特定CGI漏洞.XSS漏洞.sql注入漏洞. ...
- Hadoop 文本分类 终于跑通了
Training 入口 package org.wordCount; import java.util.ArrayList; import java.util.List; import org.apa ...
- 个人学习FPGA的初步过程
对于FPGA,完全是从零开始学习,简单讲述一下我个人学习FPGA的经历吧: 没有开发板的日子.说真的要我掏腰包买开发板觉得是一件非常奢侈的事情.理由1:现成的东西,背后影藏诸多诡异的事情我们是无法体会 ...
- HDU 4006 The kth great number 优先队列、平衡树模板题(SBT)
The kth great number Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65768/65768 K (Java/Oth ...
- CodeForces 614C Peter and Snow Blower
简单计算几何,只要算出圆心到多边形上的最短距离和最长距离即可 #include<cstdio> #include<cstring> #include<cmath> ...