iOS简单的多表查询以及SQLite注意点

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了iOS简单的多表查询以及SQLite注意点相关的知识,希望对你有一定的参考价值。

参考技术A 多表查询

假如有两张表:

表A:

表B:

这里我们是通过相同列名departmentNumber来进行条件查询相关信息:

1.内连接查询:返回的结果只有满足departmentNumber相等的结果

sql语句(有两种方式):

```

-->select a.name, b.name from A as a, B as b where a.departmentNumber = b.departmentNumber

-->select a.name, b.name from A as a  inner join  B as b on a.departmentNumber = b.departmentNumber

```

查询结果:

2.左外链接查询:返回的结果只和左边的表有关(这里假定A是左边的表),右边表如果没有对应值,就为NULL

sql语句:

```

-->select a.name, b.name from A as a  left outer join  B as b on a.departmentNumber= b.departmentNumber

```

返回结果:

3.右外链接查询:返回的结果只和右边的表有关(这里假定B是右表),那么如果左边表是没有对应值,就为NULL

sql语句:

```

-->select a.name, b.name from A as a  right OUTER join  B as b on a.departmentNumber = b.departmentNumber

```

返回结果:

4.完全外链接查询:想获取两个表所有信息,如果两个表内没有对应值的就用NULL表示

sql语句:

```

-->select a.name, b.name from B as b  full OUTER join  A as a on a.departmentNumber = b.departmentNumber

```

返回结果:

注意点:在sqlite中是不支持右外连接和完全外链接的,但是可以通过以下方式来进行连接:

1.sqlite中的右外连接:将左外连接的表换个顺序就可以了

```

-->select a.name, b.name from B as B  left outer join  A as A on a.departmentNumber = b.departmentNumber

```

返回结果:

2.sqlite中的完全外链接:用关键字union将两句连接起来进行合并

```

-->select a.name, b.name from B as b left OUTER A as a on a.departmentNumber = b.departmentNumber

UNION

select a.name, b.name from A as a left outer B as b on a.departmentNumber = b.departmentNumber

```

返回结果:

Sqlite的多表连接更新

最近处理一个较大数据的sqlite库,基础表300万条,结果表30万条左右,我的笔记本跑起来还算流畅。最后结果,需要两个表连接,把另一个表的计算结果更新过来,却遇到麻烦。sqliter并不支持常见的连接更新:

update a set a.id =b.id from table_1 a inner join table_2 b  on a.name=b.name

 

查了一下,只能这样:

update table1 set col1=(select col1 from table2 where col2=table1.col2)

试了一下,太慢了。

最后找了一个折中的办法:

1.把连接写成视图

2.导出结果到csv

3.建立一个空表,结构和视图相同

4.把csv导入到空表

5.修整相关的列

以上是关于iOS简单的多表查询以及SQLite注意点的主要内容,如果未能解决你的问题,请参考以下文章

ORM的多表查询详述

MySQL的多表关联查询

MyBatis的多表联合查询

ABP 数据库 -- ABP&EF中的多表关联查询

现身说法:实际业务出发分析百亿数据量下的多表查询优化

Mybatis从入门到精通系列 09——Mybatis多表查询之一对多查询