文档章节

Sqlite之外键约束跟内外联表

MrBryant24
 MrBryant24
发布于 2014/04/23 15:52
字数 735
阅读 5240
收藏 4

SQLite

SQLite是一种嵌入式数据库,小型高效,值得移动开发者去学习利用 当然性能要去不高可以使用apple的coreData面向对象操作关系型数据库技术 —— 百度百科

**首先我会建两个表 1.t_person 2.t_book 3.工具sqliteManager ** t_person表 t_book表

<i><b>

  1. 外键约束(reference表的属性,4个delete选项) .
  2. 外联表的连接(直接连接,左右连接,全局连接) .
  3. 连接不需要外键约束,这不是必要条件 </i></b>

开始

##外键约束

<b>

  • 如果加入了外键约束,就是如:t_person的book_id输入的值必须是存在的t_book的id,比如我设置book_id=8,但t_book没有8的id那行,那样是报错的

  • CREATE TABLE "t_person" (name text,age integer,height real,id integer PRIMARY KEY AUTOINCREMENT,"book_id" integer REFERENCES "t_book" (id) ON DELETE CASCADE ON UPDATE NO ACTION)

<h7>关键字

<i><b>

  1. Reference 表(属性).
  2. ON delete (Cascade,SetNull,Default,Res) .</i>
  • 以上删除选项分别代表瀑布删除:即系删除一个行,另外一个表中对应的行也会删除掉,例如:我把t_book表中id=2那行删除,t_person中book_id=2的那一行也会完全删除
  • SetNull就是当t_book表中id=2那行删除,t_person中book_id=2的那一行的book_id=NULL,其他不受影响
  • Default就是就是当t_book表中id=2那行删除,t_person中book_id=2的那一行不受影响

##查询连接

  • 左右连接

  • left join(表名) on 条件等式

  •   select * from t_person p 
      left join t_book b on p.book_id= b.id
    

代码意义

  • 左连接,把t_person表跟t_book表联系起来,而查询的结果的条件是 t_person.book_id= t_book.id

  • 然后把结果打印出来

##关于Left Join跟Join的选择:

left join

  • 如果要查询左边表中的所有符合条件的数据,使用left jion
  • 通常查询出来的结果会多,因为右边表不存在的记录,同样可能会被查询出来,查询出来之后,右边表不存在的记录,全部为NULL

join

  • 如果要两个表中同时存在的符合条件的数据,使用jion
  • 通常查询出来的结果会比左连接少,因为右边表不存在的记录,不会显示出来

<code><pre> 通常在使用时,左边的表是主要信息表,右边的表是辅助修饰的信息表,其内容可有可无,因此,在实际应用中,left jion使用的比较频繁!如果用join的话,有可能会“丢(有些存在的数据不显示)”数据 </code></pre>

<h3><font color="red"> 一句话解析:"查询拥有<IOSX>这些书的所有人" </font></h3>

p是person表别名-b是book别名

SELECT p.name,p.age,b.name,b.price as bookPrice

FROM t_person p

JOIN t_book b ON p.book_id =b.id

WHERE b.name LIKE 'IOS%'

© 著作权归作者所有

共有 人打赏支持
MrBryant24
粉丝 1
博文 7
码字总数 3289
作品 0
广州
程序员
私信 提问
加载中

评论(1)

MrBryant24
MrBryant24
暂时写给自己看得
DataUml Design 介绍8-DataUML 1.2版本正式发布

 DataUML 1.2版本在软件架构上有了很大的变化,目前DataUML支持Access、SQLite、MY SQL 、ORACLE、MS SERVER2000、MS SERVER2005、MS SERVER2008数据库。 下载 主要更新内容如下:   1、支...

NetUml
2014/04/22
0
0
DataUml Design 介绍8-DataUML 1.2版本正式发布

 DataUML 1.2版本在软件架构上有了很大的变化,目前DataUML支持Access、SQLite、MY SQL 、ORACLE、MS SERVER2000、MS SERVER2005、MS SERVER2008数据库。 下载 主要更新内容如下:   1、支...

NetUml
2014/04/21
0
0
sqlite rowid与主键

rowid和 Integer主键及自增属性 大多数情况下,sqlite3的表都有一个rowid(也叫oid,rowid),这是一个64位的整数,并作为sqlite存储结构B树的主键.因此使用rowid查询会比以其他设定的主键查询,速度...

IMGTN
2013/04/26
0
1
sqlite3自增key设定(创建自增字段)

在用sqlite设计表时,每个表都有一个自己的整形id值作为主键,其实可以不指定这么一个id值,sqlite内部本来就会为每个表加上一个 rowid,这个rowid可以当成一个隐含的字段使用,但是由sqlit...

尼莫
2012/11/07
0
0
Python中轻量数据库SQlite3的使用

版权声明:本文为博主 一銤阳光 学习整理的文章,如需转载,请注明出处、附上CSDN博文链接。 https://blog.csdn.net/CSDNhuaong/article/details/80793573 1.写在前面 Python SQLITE数据库是...

一銤阳光
06/24
0
0

没有更多内容

加载失败,请刷新页面

加载更多

JAVA设计模式之模板方法模式和建造者模式

一、前期回顾 上一篇《Java 设计模式之工厂方法模式与抽象工厂模式》介绍了三种工厂模式,分别是工厂方法模式,简单工厂方法模式,抽象工厂模式,文中详细根据实际场景介绍了三种模式的定义,...

木木匠
21分钟前
1
0
C中的宏的使用(宏嵌套/宏展开/可变参数宏)

基本原则: 在展开当前宏函数时,如果形参有#或##则不进行宏参数的展开,否则先展开宏参数,再展开当前宏。 #是在定义两边加上双引号 #define _TOSTR(s) #sprintf(_TOSTR(test ABC))pr...

SamXIAO
52分钟前
2
0
SpringBoot 整合异步调用方法

1. 在 SpringBoot 主类上使用 @EnableAsync 注解,开启异步调用功能 package com.codingos.springbootdemo;import org.springframework.boot.SpringApplication;import org.springfra......

北漂的我
今天
1
0
0015-如何使用Sentry管理Hive外部表权限

1.文档编写目的 本文档主要讲述如何使用Sentry对Hive外部表权限管理,并基于以下假设: 1.操作系统版本:RedHat6.5 2.CM版本:CM 5.11.1 3.集群已启用Kerberos和Sentry 4.采用具有sudo权限的...

Hadoop实操
今天
3
0
边缘计算与数据中心的发展趋势

导读 Gartner研究表明,人工智能、物联网和5G助力下一代商业创新,由此产生大量数据,2020年前企业将使用超过75亿台联网设备。 在几乎每个方面,社会的节奏都正变得更快。我们希望客户服务问...

问题终结者
今天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部