我的SQLite语法出现了错误。

5

我是新手,对SQLite不太熟悉,所以不知道哪里出了错。我只是收到了一个错误提示:

SQLSTATE[HY000]: General error: 1 near "CREATE": syntax error

这是我的SQL语句:

CREATE TABLE users (
  id INTEGER NOT NULL PRIMARY KEY,
  date_created DATETIME NOT NULL,
  date_updated DATETIME NOT NULL,
  username VARCHAR(32) NOT NULL,
  password VARCHAR(32) NOT NULL,
  role VARCHAR(32) NOT NULL DEFAULT 'member',
  first_name VARCHAR(50) NOT NULL,
  last_name VARCHAR(50) NOT NULL,
  email VARCHAR(128) NOT NULL
)

CREATE TABLE subscribers (
  id INTEGER NOT NULL PRIMARY KEY,
  name VARCHAR(40) DEFAULT NULL,
  email VARCHAR(255) NOT NULL UNIQUE
)

CREATE TABLE weekly_download (
  id INTEGER NOT NULL PRIMARY KEY,
  filename TEXT NOT NULL,
  download_date DATE NOT NULL,
  body TEXT
)
3个回答

11

在每个语句后面加上分号。

CREATE TABLE ( ... ) ;
CREATE TABLE ( ... ) ;

4

从sqlite3 CLI开始使用简单的语句。

如果您忘记了一个;,您将获得快速反馈并可以逐步构建更复杂的SQL。

$ sqlite3 /tmp/test.db
SQLite version 3.5.9
Enter ".help" for instructions
sqlite> create table badsyntax;
SQL error: near ";": syntax error
sqlite> create table abc (x,y);
sqlite> 

3

不要忘记分号!


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接