可以利用外键创建两个关联的表,代码如下:
#!/usr/bin/python
# encoding: utf-8
import MySQLdb
#功能:建数据库和表
# 打开数据库连接
conn = MySQLdb.connect(host="localhost", user="root", passwd="111111", db="testalchemy")
# 使用cursor()方法获取操作游标
cursor = conn.cursor()
# 如果数据表已经存在使用 execute() 方法删除表。
cursor.execute("DROP TABLE IF EXISTS book")
cursor.execute("DROP TABLE IF EXISTS user")
#1. 创建user表
sql = """CREATE TABLE user (
id varchar(20) primary key,
name varchar(20) )ENGINE=InnoDB DEFAULT CHARSET=latin1;"""
cursor.execute(sql)
#2. 创建book表
# 如果数据表已经存在使用 execute() 方法删除表。
#cursor.execute("DROP TABLE IF EXISTS book")
sql = """create table book (
id varchar(20) primary key,
name varchar(20),
user_id varchar(20),
foreign key (user_id) references user(id) )ENGINE=InnoDB DEFAULT CHARSET=latin1;"""
cursor.execute(sql)
conn.close()
创建的book表如下: