编写一个程序,联系人数据库会对联系人的资料模块化,分成多个表保存数据, 表与表之间使用 id 关联完整代码

时间: 2024-03-24 16:41:32 浏览: 17
好的,以下是一个简单的 Python 程序示例,用于演示如何实现联系人数据库模块化、分表保存、使用 id 关联的功能: ```python import sqlite3 # 定义联系人表结构 contact_table = ''' CREATE TABLE IF NOT EXISTS contacts ( id INTEGER PRIMARY KEY, name TEXT NOT NULL, email TEXT, phone TEXT ) ''' # 定义地址表结构 address_table = ''' CREATE TABLE IF NOT EXISTS addresses ( id INTEGER PRIMARY KEY, contact_id INTEGER NOT NULL, street TEXT, city TEXT, state TEXT, zip TEXT, FOREIGN KEY(contact_id) REFERENCES contacts(id) ) ''' # 连接数据库 conn = sqlite3.connect('contacts.db') # 创建联系人表和地址表 conn.execute(contact_table) conn.execute(address_table) # 定义函数用于添加联系人 def add_contact(name, email=None, phone=None): # 插入联系人数据到 contacts 表 cursor = conn.cursor() cursor.execute('INSERT INTO contacts (name, email, phone) VALUES (?, ?, ?)', (name, email, phone)) contact_id = cursor.lastrowid conn.commit() cursor.close() return contact_id # 定义函数用于添加地址 def add_address(contact_id, street=None, city=None, state=None, zip=None): # 插入地址数据到 addresses 表 cursor = conn.cursor() cursor.execute('INSERT INTO addresses (contact_id, street, city, state, zip) VALUES (?, ?, ?, ?, ?)', (contact_id, street, city, state, zip)) conn.commit() cursor.close() # 添加几个联系人和地址 john_id = add_contact('John Doe', 'john@example.com', '555-1234') add_address(john_id, '123 Main St', 'Anytown', 'CA', '12345') jane_id = add_contact('Jane Smith', 'jane@example.com') add_address(jane_id, '456 Oak Ave', 'Somewhere', 'NY', '67890') # 查询联系人和地址 cursor = conn.cursor() cursor.execute('SELECT contacts.name, addresses.street, addresses.city, addresses.state, addresses.zip FROM contacts JOIN addresses ON contacts.id = addresses.contact_id') rows = cursor.fetchall() for row in rows: print(row) # 关闭连接 conn.close() ``` 在这个示例中,我们使用 SQLite 数据库来保存联系人和地址数据。程序中定义了两个表,分别为 contacts 和 addresses,联系人表保存联系人的姓名、电子邮件和电话号码,地址表保存联系人的地址信息。这两个表之间使用 contact_id 字段进行关联。 程序中定义了两个函数,一个用于添加联系人,另一个用于添加地址。我们可以通过这两个函数向数据库中插入数据。在本例中,我们添加了两个联系人 John Doe 和 Jane Smith,每个联系人都有一个地址。最后,我们从数据库中查询了联系人和地址信息,并将其输出到控制台。 请注意,这只是一个简单的示例程序,您可以根据自己的需要进行修改和扩展。

相关推荐

最新推荐

recommend-type

java编写创建数据库和表的程序

主要为大家详细介绍了java编写创建数据库和表的程序,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

88秒插入1000万条数据到MySQL数据库表的操作方法

主要介绍了88秒插入1000万条数据到MySQL数据库表的操作方法,首先给大家说下我用到的数据库表为mysql数据库5.7版本的。具体操作方法大家跟随小编一起通过本文学习吧
recommend-type

表驱动LL(1)语法分析程序.docx

(1)根据LL(1)分析法编写一个语法分析程序,输入文法的FIRST(α)和FOLLOW(U)集,由程序自动生成文法的预测分析表。 (2)所开发的程序可适用于不同的文法和任意输入串,且能判断该文法是否为LL(1)文法。 (3)对输入的...
recommend-type

微信小程序云开发修改云数据库中的数据方法

例如:数据库表中的_openid字段是自动生成的,哪个用户创建的记录这个openid就是用户的openid,云数据库的权限分配也是根据openid来进行的。 解决方案: 第一步:创建云函数,在函数中编写修改数据库的操作代码 // ...
recommend-type

3分钟如何向MySQL数据库中插入100万条数据

一、编写测试案例向MySQL数据库中插入百万条数据。测试数据表建表脚本如下:use db_xk; drop table if exists tb_test2; create table tb_test2 ( id int primary key auto_increment, subject varchar(50) ...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【实战演练】MATLAB用遗传算法改进粒子群GA-PSO算法

![MATLAB智能算法合集](https://static.fuxi.netease.com/fuxi-official/web/20221101/83f465753fd49c41536a5640367d4340.jpg) # 2.1 遗传算法的原理和实现 遗传算法(GA)是一种受生物进化过程启发的优化算法。它通过模拟自然选择和遗传机制来搜索最优解。 **2.1.1 遗传算法的编码和解码** 编码是将问题空间中的解表示为二进制字符串或其他数据结构的过程。解码是将编码的解转换为问题空间中的实际解的过程。常见的编码方法包括二进制编码、实数编码和树形编码。 **2.1.2 遗传算法的交叉和
recommend-type

openstack的20种接口有哪些

以下是OpenStack的20种API接口: 1. Identity (Keystone) API 2. Compute (Nova) API 3. Networking (Neutron) API 4. Block Storage (Cinder) API 5. Object Storage (Swift) API 6. Image (Glance) API 7. Telemetry (Ceilometer) API 8. Orchestration (Heat) API 9. Database (Trove) API 10. Bare Metal (Ironic) API 11. DNS
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。