SQLite外键全面解析

一、什么是SQLite外键

SQLite外键是指将两个表格关联起来的键,用于确保数据的一致性和完整性,是数据库设计中最关键的一环。

在SQLite中,外键指一个表格中的一列或者多列值需要与另一个表格中的某一列值保持一致,以此来确保数据的一致性。

二、定义外键的方法

在定义表的时候,需要在需要参考其他表格的列名后面加上“REFERENCES”关键字,接着是被参考的表格名和被参考的列名。具体语法如下:

CREATE TABLE table_name (
  column1 datatype CONSTRAINT constraint_name REFERENCES referenced_table (referenced_column),
  column2 datatype,
  column3 datatype,
  .....
);

其中,“column1”是需要定义为外键的列名,“datatype”是数据类型,“constraint_name”是定义的外键约束名字,“referenced_table”是被参考的表格名,“referenced_column”是被参考的列名。

三、外键的约束种类

1. CASCADE

若主表中删除了一条记录,那么从表中与此记录关联的数据行也将被自动删除。

CREATE TABLE students (
	id INTEGER PRIMARY KEY,
	name TEXT,
	age INTEGER);

CREATE TABLE courses (
	id INTEGER PRIMARY KEY,
	course_name TEXT,
	student_id INTEGER,
	FOREIGN KEY(student_id) REFERENCES students(id) ON DELETE CASCADE);

2. RESTRICT

若主表中删除了一条记录,那么从表中如果有要与此记录关联的数据行,删除操作将被拒绝。

CREATE TABLE students (
	id INTEGER PRIMARY KEY,
	name TEXT,
	age INTEGER);

CREATE TABLE courses (
	id INTEGER PRIMARY KEY,
	course_name TEXT,
	student_id INTEGER,
	FOREIGN KEY(student_id) REFERENCES students(id) ON DELETE RESTRICT);

3. NO ACTION

若主表中删除了一条记录,那么从表中如果有要与此记录关联的数据行,将会限制此操作,但是不会有任何动作被执行。

CREATE TABLE students (
	id INTEGER PRIMARY KEY,
	name TEXT,
	age INTEGER);

CREATE TABLE courses (
	id INTEGER PRIMARY KEY,
	course_name TEXT,
	student_id INTEGER,
	FOREIGN KEY(student_id) REFERENCES students(id) ON DELETE NO ACTION);

4. SET NULL

若主表中删除了一条记录,那么从表中与此记录关联的数据行的外键值将被设置为 NULL。

CREATE TABLE students (
	id INTEGER PRIMARY KEY,
	name TEXT,
	age INTEGER);

CREATE TABLE courses (
	id INTEGER PRIMARY KEY,
	course_name TEXT,
	student_id INTEGER,
	FOREIGN KEY(student_id) REFERENCES students(id) ON DELETE SET NULL);

5. SET DEFAULT

若主表中删除了一条记录,那么从表中与此记录关联的数据行的外键值将被设置为默认值。

CREATE TABLE students (
	id INTEGER PRIMARY KEY,
	name TEXT,
	age INTEGER);

CREATE TABLE courses (
	id INTEGER PRIMARY KEY,
	course_name TEXT,
	student_id INTEGER DEFAULT 1,
	FOREIGN KEY(student_id) REFERENCES students(id) ON DELETE SET DEFAULT);

四、外键的查询方法

可以使用“PRAGMA foreign_key_list(table_name)”来查看指定表的外键约束信息。

PRAGMA foreign_key_list(courses);

结果如下:

0|courses|student_id|students|id|RESTRICT|NO ACTION|NONE

五、外键的局限性

SQLite对外键的支持存在以下局限性:

  • 不能定义跨库的外键;
  • 不能定义触发器或者存储过程;
  • 不能复合外键;
  • 在SQLite默认情况下是不支持外键的,需要手动开启外键约束。

六、手动开启SQLite外键约束

在创建数据库连接时,需要手动开启外键约束。具体实现方法是调用sqlite3_exec函数执行PRAGMA语句,如下所示:

sqlite3 *db;
sqlite3_open("test.db", &db);
char *zErrMsg = 0;
sqlite3_exec(db, "PRAGMA foreign_keys = ON;", 0, 0, &zErrMsg);

七、总结

SQLite外键用于确保数据的一致性和完整性,在数据库设计中起着至关重要的作用。SQLite支持多种外键约束,包括CASCADE、RESTRICT、NO ACTION、SET NULL和SET DEFAULT,并且可以使用PRAGMA语句查询指定表的外键信息。但是,SQLite对外键的支持存在一些局限性,需要开发人员在使用时注意。

原创文章,作者:ISCPF,如若转载,请注明出处:https://www.506064.com/n/332424.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
ISCPFISCPF
上一篇 2025-01-24 18:46
下一篇 2025-01-24 18:46

相关推荐

  • Python应用程序的全面指南

    Python是一种功能强大而简单易学的编程语言,适用于多种应用场景。本篇文章将从多个方面介绍Python如何应用于开发应用程序。 一、Web应用程序 目前,基于Python的Web…

    编程 2025-04-29
  • Python zscore函数全面解析

    本文将介绍什么是zscore函数,它在数据分析中的作用以及如何使用Python实现zscore函数,为读者提供全面的指导。 一、zscore函数的概念 zscore函数是一种用于标…

    编程 2025-04-29
  • 全面解读数据属性r/w

    数据属性r/w是指数据属性的可读/可写性,它在程序设计中扮演着非常重要的角色。下面我们从多个方面对数据属性r/w进行详细的阐述。 一、r/w的概念 数据属性r/w即指数据属性的可读…

    编程 2025-04-29
  • Python计算机程序代码全面介绍

    本文将从多个方面对Python计算机程序代码进行详细介绍,包括基础语法、数据类型、控制语句、函数、模块及面向对象编程等。 一、基础语法 Python是一种解释型、面向对象、动态数据…

    编程 2025-04-29
  • Matlab二值图像全面解析

    本文将全面介绍Matlab二值图像的相关知识,包括二值图像的基本原理、如何对二值图像进行处理、如何从二值图像中提取信息等等。通过本文的学习,你将能够掌握Matlab二值图像的基本操…

    编程 2025-04-28
  • 疯狂Python讲义的全面掌握与实践

    本文将从多个方面对疯狂Python讲义进行详细的阐述,帮助读者全面了解Python编程,掌握疯狂Python讲义的实现方法。 一、Python基础语法 Python基础语法是学习P…

    编程 2025-04-28
  • 全面解析Python中的Variable

    Variable是Python中常见的一个概念,是我们在编程中经常用到的一个变量类型。Python是一门强类型语言,即每个变量都有一个对应的类型,不能无限制地进行类型间转换。在本篇…

    编程 2025-04-28
  • Zookeeper ACL 用户 anyone 全面解析

    本文将从以下几个方面对Zookeeper ACL中的用户anyone进行全面的解析,并为读者提供相关的示例代码。 一、anyone 的作用是什么? 在Zookeeper中,anyo…

    编程 2025-04-28
  • Switchlight的全面解析

    Switchlight是一个高效的轻量级Web框架,为开发者提供了简单易用的API和丰富的工具,可以快速构建Web应用程序。在本文中,我们将从多个方面阐述Switchlight的特…

    编程 2025-04-28
  • Python合集符号全面解析

    Python是一门非常流行的编程语言,在其语法中有一些特殊的符号被称作合集符号,这些符号在Python中起到非常重要的作用。本文将从多个方面对Python合集符号进行详细阐述,帮助…

    编程 2025-04-28

发表回复

登录后才能评论