简体   繁体   English

创建表时我的python + sqlite3代码有什么问题?

[英]What's wrong with my python + sqlite3 code in creating tables?

I'm trying to create a database with several tables connecting to each other using foreign keys using sqlite3, and I'm writing in python. 我正在尝试使用sqlite3使用外键创建具有多个相互连接的表的数据库,并且我正在用python编写。

Here is my code: 这是我的代码:

db = sqlite3.connect("PHLC.db")
cur = db.cursor()

# ############################
# delete original table if exist
# drop from the end (foreign key issue)
cur.execute("drop table if exists measurement")
cur.execute("drop table if exists mouse")
cur.execute("drop table if exists drug")
cur.execute("drop table if exists batch")
cur.execute("drop table if exists phlc")

# ############################
# create table
# ############################
# 1. phlc
cur.execute(
    """
    CREATE TABLE phlc (
    phlc_id INTEGER NOT NULL PRIMARY KEY,
    cancer VARCHAR(30) NOT NULL,
    histology VARCHAR(60) NOT NULL
    )
    """
)
# 2. batch
cur.execute(
    """
    CREATE TABLE batch (
    batch_id INTEGER PRIMARY KEY AUTOINCREMENT,
    phlc_id INTEGER NOT NULL,
    FOREIGN KEY (phlc_id) REFERENCES phlc (phlc_id),
    batch_number INTEGER NOT NULL
    )
    """
)
# 3. drug
cur.execute(
    """
    CREATE TABLE drug (
    drug_id INTEGER PRIMARY KEY AUTOINCREMENT,
    drug_name VARCHAR(30) NOT NULL,
    batch_id INTEGER NOT NULL,
    FOREIGN KEY (batch_id) REFERENCES batch (batch_id)
    )
    """
)
# 4. mouse
cur.execute(
    """
    CREATE TABLE mouse (
    mouse_id INTEGER PRIMARY KEY AUTOINCREMENT,
    drug_id INTEGER NOT NULL,
    FOREIGN KEY (drug_id) REFERENCES drug (drug_id)
    )
    """
) 
# 5. measurement
cur.execute(
    """
    CREATE TABLE measurement (
    measurement_index INTEGER PRIMARY KEY AUTOINCREMENT,
    mouse_id INTEGER NOT NULL,
    FOREIGN KEY (mouse_id) REFERENCES mouse (mouse_id),
    day INTEGER NOT NULL,
    tumor_volume FLOAT NOT NULL,
    comment VARCHAR(255) NULL
    )
    """
) 

db.commit()
db.close()

The error I'm getting is at the batch table: 我得到的错误是在批处理表:

sqlite3.OperationalError: near "batch_number": syntax error

Can someone point out the problem with the code? 有人可以指出代码的问题吗? (It worked fine with MySQL..) (它与MySQL配合良好。)

According to the documentation , any table constraints must come after all column definitions: 根据文档 ,所有表约束必须位于所有列定义之后:

CREATE TABLE batch (
    batch_id INTEGER PRIMARY KEY AUTOINCREMENT,
    phlc_id INTEGER NOT NULL,
    batch_number INTEGER NOT NULL,
    FOREIGN KEY (phlc_id) REFERENCES phlc (phlc_id)
)

Alternatively, make the foreign key declaration a column constraint: 或者,使外键声明成为列约束:

CREATE TABLE batch (
    batch_id INTEGER PRIMARY KEY AUTOINCREMENT,
    phlc_id INTEGER NOT NULL REFERENCES phlc (phlc_id),
    batch_number INTEGER NOT NULL
)

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM