qt mysql外键_【Qt笔记】编辑数据库外键

本文介绍了如何在Qt中启用数据库的外键约束,并使用QSqlRelationalTableModel来显示和编辑包含外键的表格数据。通过设置外键关联,实现了在编辑时自动显示参照表的字段值,简化了用户界面的操作。

前面几章我们介绍了如何对数据库进行操作以及如何使用图形界面展示数据库数据。本章我们将介绍如何对数据库的数据进行编辑。当然,我们可以选择直接使用 SQL 语句进行更新,这一点同前面所说的 model/view 的编辑没有什么区别。除此之外,Qt 还为图形界面提供了更方便的展示并编辑的功能。

普通数据的编辑很简单,这里不再赘述。不过,我们通常会遇到多个表之间存在关联的情况。首先我们要提供一个 city 表:

CREATE TABLE city (

id INTEGER PRIMARY KEY AUTOINCREMENT,

name VARCHAR);

INSERT INTO city (name) VALUES ('Beijing');

INSERT INTO city (name) VALUES ('Shanghai');

INSERT INTO city (name) VALUES ('Nanjing');

INSERT INTO city (name) VALUES ('Tianjin');

INSERT INTO city (name) VALUES ('Wuhan');

INSERT INTO city (name) VALUES ('Hangzhou');

INSERT INTO city (name) VALUES ('Suzhou');

INSERT INTO city (name) VALUES ('Guangzhou');

由于 city 表是一个参数表,所以我们直接将所需要的城市名称直接插入到表中。接下来我们创建 student 表,并且使用外键连接 city 表:

CREATE TABLE student (

id INTEGER PRIMARY KEY AUTOINCREMENT,

name VARCHAR,

age INTEGER,

address INTEGER,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值