大家好,
我在使用sqlite3和python3时遇到了一些麻烦。我想我再次遇到了那些愚蠢的时刻之一,但我正试图在下面制作下表。
关键点似乎是外键 - 我做错了什么,但我还没有弄清楚什么 - 而且我的谷歌搜索并没有真正让我到处都是。我找不到任何好的文件。我已经为外键在线尝试了多种不同的语法,但没有一种能让我更接近工作表。
c.execute('''
CREATE TABLE Driver (
ID INTEGER PRIMARY KEY NOT NULL UNIQUE AUTOINCREMENT,
FirstName text,
LastName text,
RegistrationNo text)
''')
c.execute('''
CREATE TABLE Passenger (
ID INTEGER PRIMARY KEY NOT NULL UNIQUE AUTOINCREMENT,
FirstName text,
LastName text)
''')
c.execute('''
pragma foreign_keys=on;
begin transaction;
CREATE TABLE Journey (
ID INTEGER PRIMARY KEY NOT NULL UNIQUE AUTOINCREMENT,
Driver_ID INTEGER NOT NULL
FOREIGN KEY (Driver_ID) REFERENCES Driver,
Origin text,
Destination text,
SeatsAvailable integer,
Date text,
Time text,
DriverNotes text,
PassengerNotes text)
''')
c.execute('''
pragma foreign_keys=on;
begin transaction;
CREATE TABLE Assigned Passengers (
ID INTEGER PRIMARY KEY NOT NULL UNIQUE AUTOINCREMENT,
Journey_ID INTEGER NOT NULL
FOREIGN KEY (Journey_ID) REFERENCES Journey,
Passenger_ID INTEGER NOT NULL
FOREIGN KEY (Passenger_ID) REFERENCES Passenger
''')
我得到的一条消息是 -
Traceback (most recent call last):
File "/Users/Computer/Bitbucket/Python Project/sql.py", line 46, in <module>
''')
sqlite3.Warning: You can only execute one statement at a time.
第46行位于旅程创建块的末尾。
提前感谢任何可以提供帮助的人:)
答案 0 :(得分:2)
PRAGMA foreign_keys
一次连接即可。BEGIN TRANSACTIOn
在这里毫无意义。c.execute('''
CREATE TABLE Journey (
ID INTEGER PRIMARY KEY AUTOINCREMENT,
Driver_ID INTEGER NOT NULL REFERENCES Driver(ID),
Origin text,
Destination text,
SeatsAvailable integer,
Date text,
Time text,
DriverNotes text,
PassengerNotes text)
''')
c.execute('''
CREATE TABLE Assigned_Passengers (
ID INTEGER PRIMARY KEY AUTOINCREMENT,
Journey_ID INTEGER NOT NULL REFERENCES Journey(ID),
Passenger_ID INTEGER NOT NULL REFERENCES Passenger(ID))
''')