iOS数据库之基础知识get

iOS中进行数据持久化存储有几种方式

  • plist(NSArray NSDictionary只用来存储数组和字典,并且数组和字典中不能有自定义对象,有自定义对象)
  • preference偏好设置也不能存储自定义对象
  • nscoding归档:用来存储自定义对象.局限性:一次性做存储/读取操作.------------------而离线缓存是有时是一次一次增加,如果用归档,就需要,从数组中读取出来加入数组,再重新存入.不能单独添加某一个东西.必须一次性添加进去.
    比如有
    80条数据,需要再增加20条,我们就需要取出放入数组,再一次性存入100条
  • Sqlite数据库就是用来做离线缓存的

做离线缓存,目的是为了在没有网络时,可以进行加载数据

1.什么是SQLite,

SQLite是一款轻型的嵌入式数据库,占用资源非常低,在嵌入式的设备中,可能只需要几百k的内存就够了.她的处理速度比Mysql postgreSQL这两款数据库都快.Mysql postgreSQL这两种是大型数据库.我们手机不需要用到这种大型数据库.

2.什么数据库

是用来存储和管理数据的仓库

3.数据库的两大分类

关系型数据库
对象性数据库coredata

关系型数据库

4.sqlited数据库的优点

  1. 操作数据比较快,读取比较方便
  1. 可以局部读取
  2. 比较小型,占用内存小符合手机的特点≈

5.sqlited数据库是如何存取数据的

数据库和excel类似,是以表为单位的.表的名字

6.操作数据的步骤

  1. 创建数据库表,表名通常以t_开头,比如t_student
  1. 设计表,根据表需要存储什么数据,比如,学生有学号 姓名 年龄等等
  2. 记录数据 设置学生 12号 张明 15岁
  3. 插入其他数据,13号 李敏 15岁;这种每一条信息叫一条记录每一列叫一个字段
  4. 主键,数据库中每一条数据的唯一标识,一般每个表只用一个主键
  5. 数据类型
    Integer(整形)
    real 浮点型 text(文本)
    blob(二进制数据比如文件,NSDate本身就是二进制) 无类型

7.什么是SQL?

结构化查询语言是一种对关系型数据库中的数据进行定义和操作的语言
SQL语句是使用SQL语言编写出来的句子/代码
在程序运行期间,要想操作数据库中的数据(增删改查),必须使用SQL语句

8.SQL语句的规则

  1. 不区分大小写
  1. 每条语句都必须以;分号结尾
  2. 不能以关键字来命名表/字段

9.SQL语句的种类

  • 数据定义语句DDL(data definition language)
    create table drop table在数据库中创建新表或删除表
  • 数据库操作语句DML(data manipulation language)
    insert update delete 在数据库中对表进行插入添加.修改.删除表中的数据
  • 数据查询语句DQL(data query language)
    select where orderly groupie having用于查询表中数据

10.DDL数据创建语句
创建表格

  1. create table 表名(字段1,字段类型1,字段2,字段类型2.....)
  1. create table if not exists 表名 (字段1 字段类型1,字段2 字段类型2)
  2. create table if not exists stu(s_id integer primary key autoincrement not null)顺序不能调货,主键是整形的只有整形才能自增

删除表格

  1. drop table 表名
  1. drop table if exists 表名

11.DML数据库操作语句----增删改
数据库中的字符串内容应该用单引号’括住
插入数据

  1. insert into 表名(字段名1,字段名2.。。。)values(字段1值,字段2值。。。。)
  1. insert into stu (s_name,s_age) values ('aa',18)
    id 是系统自增的
    insert into mall (m_name,m_price,m_date) values ('牙膏',12.5,'20150101')

更改数据

  1. update 表名 set 字段名1 = 修改值1,字段名2 = 修改值2, (无条件全部更新)
    条件
    where 字段名 条件 条件值(<,>,!=.....)
    and or 关键词:并且 或
  1. update stu set s_age = 9999 where s_age >10 and s_age<20
  2. update stu set s_age = 18 where s_age =1000 or s_age=9999

删除
delete from stu 无条件全部删除
delete from stu where s_age = 26

12.数据查询语句DQL
查找 ** select * 通配符代表所有字段**
select 字段1,字段2,。。。from 表名 where 字段名 条件 条件值

  1. select * from stu where s_age = 18
  1. select * from stu(表名)

模糊查询 所有字段全查

  1. select * from stu where s_name like ‘a_d’下划线代表一个字母 所有字段全查
  1. select * from stu where s_name like 'a_'
  2. select * from stu where s_name like 'a%’不确定a后面有几个字母用%

单查某个字段

  1. select s_name from stu
    查找某几个字段用逗号隔开
  1. select s_name,s_age from stu

排序

  1. selected * from 表名 order by 字段名 升序asc/降序desc
  1. select * from stu order by s_age asc 按照年龄升序排列
  2. select * from stu where s_age > 50 order by s_age asc 年龄大于50并按照升序排列

limit 可以精确控制查询结果的数量,比如每次只查询10条数据

  1. select * from 表名 limit 数值1, 数值2; 跳过数值1条数据开始查找数值2条
  1. select * from stu limit 5; 只查前5条只跟1个数值,从头开始查多少个
  2. select * from stu limit 3,7; 从第4条开始查7条
  3. select * from stu where s_age > 50 order by s_age asc limit 3; 年龄大于50的3条,并按照升序排列
51B9C947-EA20-4517-BA5D-76DE5A2231EA.png
69A5A743-911D-41EE-8903-C2B2FAF74308.png

13.外键约束
利用外键约束创建表与表之间的关系
某个表的字段引用其他表的主键
t_students表->编辑->Foreign keys -> + -> fk_status_user

create table t_student(id integer primary key auto increment,name text,age integer,class_id integer,constraint fk_t_student_class_id_t_class_id foreign key(class_id) references t_class(id));

主键:唯一标识/自增/不能为空
id integer primary key auto increment 主键
name text,
age integer
class_id integer
constraint约束的意思 外键名称: fk_t_student_class_id_t_class_id
foreign key(class_id) references t_class(id)这个外键的作用是用t_student表中的class_id字段引用t_class表的id字段

69A5A743-911D-41EE-8903-C2B2FAF74308.png

14.表连接查询----需要联合多张表才能查到想要的数据
表连接的类型

内连接:inner join或者join (显示的是左右表都有完整字段值的记录)
外连接:left outer join (保证左表数据的连接性)
查询0316班的所有学生(给表替换名称,使用.语法)
select s.name,s.age from t_students s,t_class c where s.class_id = c.id and.name = “0316”;

以上均来自网上查询。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,605评论 18 399
  • 一、iOS应用数据存储的常用方式: 1> XML属性列表(plist)归档2> Preference(偏好设置)3...
    DB001阅读 1,461评论 0 5
  • 一. Java基础部分.................................................
    wy_sure阅读 3,807评论 0 11
  • 我想给你看清晨金色澄净的树影 我想给你看深夜流云里碎裂的星子 有幼兽青灰色的眼眸 还有阳光清浅、水波温柔 所以我把...
    一咕阅读 149评论 0 0
  • 爆竹声震千家户,侧耳闻听暂避孤。 浪子谁知心意苦,通宵独坐饮屠苏。 残烛摇曳犹为伴,好梦新成旧恨除。 去岁经尘全忘...
    竹影斋主人阅读 175评论 5 9