在iOS中,根据不同的需求对应的有多种数据存储方式:

1.NSUserdefaults  将数据存储到沙盒中(library),方便易用,但是只能存储系统提供的数据类型(plist),不能存储自定义的model。

2,NSKeyedArchiver/NSKeyedArchiver归档,解归档/序列化,解序列化,同样将数据存储到沙盒中,由于是将数据进行序列化存储,所以,归档支持存储自定义的model(遵守NSCoding协议,实现协议方法),由于过程相对复杂,而且不能方便的增加删减内容,所以多用于存储安全性要求高,比较稳定、成熟的数据。

3,Core Data 苹果官方给出的数据存储方式,有待研究。

4.SQLite,轻量级的数据库。可移植性强(可以跨平台使用),管理操作简便。使用第三方fmdb,管理数据轻松加愉快。

以下是SQLite的常用的语句:

《1》创建表格  需要判断表格是否存在,如果不存在,才创建新的

createtableifnotexists student(

num integer primary key autoincrementnotnull,

name varchar(100) notnull,

sex booleannotnull,

birth date,

tel text

)

《2》插入数据 insert into (除了数字以外,其他的都需要加单引号)

insert into student(name,sex,birth,tel) values ('jack', 'true', '2010-2-2','13123456787')

创建表格时指定不能为空的字段在插入时必须有值,可为空的可以缺省

insert into student(name,sex,birth) values ('ios', 'false', '2010-1-2')

《3》查找

查找全部

select * from student

查找部分值

select name from student

select name,sex from student

查找 加条件, 用 where

select * from student where num=3

查找 ,多个条件用and

select num,name from student where num>=3 and num<=6

查找,条件有范围用between

select num,name from student where num between 3 and 6

查找 条件是字符串

select * from student where name='apple'

值用 单引号、双引号都可以

select * from student where name="jack"

查找 条件是字符串 like

select * from student where name like 'jack'

查找以 某个字符串开头的值 (%代表任意长度,因此使用时效率比较低,建议放在后面,不要放到前面)

select * from student where name like 'j%'

查找以 某个字符串结束的值

select * from student where name like '%k'

查找 _代表任意的一个字符

select * from student where name like '_a%'

多个条件用and

select * from student where name like '_a%' and num=3

查找 根据某个字段的升序(asc)进行排序

select * from student order by num asc

查找 根据某个字段的降序(desc)进行排序

select * from student order by name desc

查找 根据多个条件依次排序

select * from student order by birth asc, num desc

count(*) 聚合函数, group by 根据什么分组

select count(*) from student group by birth

分组的条件,和分组后每个组的个数。

group by 只能显示每个分组的个数(聚合函数)、或者分组的条件

select birth,count(*) from student group by birth

order by排序一定放在后面

select birth,count(*) from student group by birth order by count(*) desc

在表中找出学号>2的根据生日进行分组,然后根据分组后的个数降序显示每个生日的个数

select birth,count(*) from student where num>2 group by birth order by count(*) desc

as进行重命名, 将count(*) 改为 count_1

select birth,count(*) as count_1 from student where num>2 group by birth order by count_1 desc

as进行重命名

select num as t_num , name from student where t_num>3

子查询条件用having。 班里学号大于2的学生根据生日进行分组,显示分组之后个数大于等于2个人的分组的生日和个数,根据个数降序排列显示

select birth,count(*) as count_1 from student where num>2 group by birth having count_1>=2 order by count_1 desc

执行顺序:where —> select —> 执行group by —> 执行聚合函数count(*) —> having,二次筛选 —> order by 排序

查找注意事项:

1. select 后面 * 慎用,用什么查什么,提高效率

2. where后面尽量选择用主键筛选 (索引相当于目录,数据库建主键后自动建索引,所以查主键,效率会高,查询速度快,优化查询。索引类似二叉数。索引缺点一二,如果多了或者少了,不仅要改数据,还要改索引,即增删改会变慢,查询速度快,缺点三多占存储空间)

 

《4》删除数据  delete from where, 如果没有删除的条件,会将表格中所有的数据都删除掉

delete from student where num>4

《5》修改数据 ,更新数据 update

update student set name='rose21' where name like 'rose'

更新多个字段 ,注意:主键不允许更新为已经存在的值,要保证主键的值唯一

update student set name='happy' , birth='2010-11-11' where num=2

《6》删除表格,销毁表格

drop table student

《6》表连接查询

创建学生表格

createtable  ifnotexists jrstudent(

num integer primary key autoincrementnotnull,

name varchar(100) notnull,

age integer,

classNum integer  notnull

)

创建班级表格

createtable  ifnotexists jrclass(

c_num integer primary keynotnull,

c_name varchar(100) notnull

)

 

插入学生数据

insertinto jrstudent(name, classNum,age) values ('apple', 1, 21)

insertinto jrstudent(name, classNum,age) values ('rose', 1, 20)

insertinto jrstudent(name, classNum,age) values ('jack', 2, 21)

插入班级数据

insertinto jrclass(c_num, c_name) values (1, 'java')

insertinto jrclass(c_num, c_name) values (2, 'ios')

 

表连接查询   inner join on 内连接

select * from jrstudent  innerjoin jrclass on jrstudent.classNum=jrclass.c_num

 

表连接查询   简化操作,为表取别名

select * from jrstudent s innerjoin jrclass c on s.classNum=c.c_num

 

显示部分信息

select s.num,s.name,c.c_name from jrstudent s innerjoin jrclass c on s.classNum=c.c_num

显示部分信息

select s.num,s.name,c.* from jrstudent s innerjoin jrclass c on s.classNum=c.c_num

 

当两个表连接之后,如果字段名(列名)唯一时,可以直接写列名

select name,c_name from jrstudent s innerjoin jrclass c on s.classNum=c.c_num where age>20

ios中常见数据存储方式以及SQLite常用的语句的更多相关文章

  1. IOS中的数据存储方式,特点,使用情况

    数据存储的核心都是写文件,主要有四种持久化方式:属性列表(Plist),对象序列化,SQLite数据库,CoreData. 存储Plist: 键值进行存储,不能存储对象.对象需要序列化编码才能写入文件 ...

  2. iOS中的数据存储方式_SQLite3

    优点: 1) SQLite是一款轻型的嵌入式数据库; 2) 它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了 3) 它的处理速度比Mysql.PostgreSQL这两款著名的数据库都还 ...

  3. iOS中的数据存储方式_Preference(NSUserDefaults)

    NSUserDefaults适合存储轻量级的本地数据,项目中,我会把一些简单的数据密码.网址.登陆状态BOOL.整型/浮点型数据等和用户有关的数据用它存储.但是它不能存储自定义的对象! 实例化一个 N ...

  4. iOS中的数据存储方式_Plist

    plist文件只能存储OC常用数据类型(NSString.NSDictionary.NSArray.NSData.NSNumber等类型)而不能直接存储自定义模型对象; 我们拿NSData举例: /* ...

  5. iOS中的数据持久化方式

    iOS中的数据持久化方式,基本上有以下四种:属性列表.对象归档.SQLite3和Core Data. 1.属性列表 涉及到的主要类:NSUserDefaults,一般 [NSUserDefaults ...

  6. 怎样实现IOS开发中的数据存储方式

    iOS 开发中,一般有如下几种数据存储方式.需要根据具体的业务场景,选择 合适的数据存储方式. (1)  用户默认设置 – 这种情况通常不需要用户干预,如游戏通关信息,Video 播放记录,或者 Ap ...

  7. 安卓中的数据存储方式以及ContentProvider的简单介绍

    1.介绍android的数据存储方式 File存储 sharedPrefrence存储方式 conmtentprovider sqlitedatabase 网络存储   2.请介绍下ContentPr ...

  8. iOS中的数据存储

    SQLite3 SQLite3是一款开源的嵌入式关系型数据库,可移植性好,易使用,内存开销小. SQLite3是无类型的,意味着你可以保存任何类型的数据到任意表的任意字段中. SQLite3常用的4种 ...

  9. iOS开发_数据存储方式

    对于数据持久化的问题,博主并不准备在博文内放很多的代码进行更深一步解释,只是简单的介绍一下四种数据持久化,如有时间,会另外针对各个数据持久化的方法进行更进一步的阐述. 直接进入主题: 〈1.NSUse ...

随机推荐

  1. WinForm------TreeListLookUpEdit控件的使用

    1.数据库添加表dbo.Graduation 2.从工具栏拖出TreeListLookUpEdit控件,修改部分属性 Display Name:选中后显示在控件的值 Value Member:C#代码 ...

  2. python数据库操作常用功能使用详解(创建表/插入数据/获取数据)

    实例1.取得MYSQL版本 复制代码 代码如下: # -*- coding: UTF-8 -*-#安装MYSQL DB for pythonimport MySQLdb as mdbcon = Non ...

  3. Maven入门学习,安装及创建项目

    一.maven介绍: 1.maven是一个基于项目对象模型(POM Project Object Model),通过配置文件管理项目的工具(项目管理工具). 2.maven主要功能:发布项目(从编译到 ...

  4. 关闭和启动adb服务命令

    在运行中输入 关闭——adb kill-server 重启——adb start-server

  5. 使用ASP.NET Web Api构建基于REST风格的服务实战系列教程【七】——实现资源的分页

    系列导航地址http://www.cnblogs.com/fzrain/p/3490137.html 前言 这篇文章我们将使用不同的方式实现手动分页(关于高端大气上档次的OData本文暂不涉及,但有可 ...

  6. shelve模块理解

    import shelve import sys def store_person(db): pid = input("Enter unique ID mnumber:") per ...

  7. Orchard源码分析(5.1):Host初始化(DefaultOrchardHost.Initialize方法)

    概述 Orchard作为一个可扩展的CMS系统,是由一系列的模块(Modules)或主题(Themes)组成,这些模块或主题统称为扩展(Extensions).在初始化或运行时需要对扩展进行安装:De ...

  8. zabbix进程构成

    了解完zabbix特性之后,本该进入zabbix安装教程,但是我觉得在安装之前我们很有必要了解一下zabbix进程组成结构,默认情况下zabbix包含5个程序:zabbix_agentd.zabbix ...

  9. js使用split函数按照多个字符对字符串进行分割的方法

    这篇文章主要介绍了js使用split函数按照多个字符对字符串进行分割的方法,实例分析了split函数的使用技巧,非常具有实用价值,需要的朋友可以参考下   本文实例讲述了js使用split函数按照多个 ...

  10. vim查找替换

    http://www.cnblogs.com/ltang/articles/2034291.html %: 表示百分百,表示所有 行的意思... 如果不指定行号, 则表示当前行; g: 表示一行中的所 ...