Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/69.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 为什么我得到Sqlite3的数据类型文本错误?_Python_Sql_Database_Sqlite_Create Table - Fatal编程技术网

Python 为什么我得到Sqlite3的数据类型文本错误?

Python 为什么我得到Sqlite3的数据类型文本错误?,python,sql,database,sqlite,create-table,Python,Sql,Database,Sqlite,Create Table,我正在回顾其他人在Python中使用Sqlite3创建表的代码,我认为我的代码实际上是匹配的,但我一直得到一个错误。有人能帮我理解我哪里出错了吗?谢谢大家! import sqlite3 conn = sqlite3.connect('finances.db') c = conn.cursor() c.execute("CREATE TABLE IF NOT EXISTS orders (ID INT, DATE TEXT, CHECK TEXT, AMOUNT REAL,DES

我正在回顾其他人在Python中使用Sqlite3创建表的代码,我认为我的代码实际上是匹配的,但我一直得到一个错误。有人能帮我理解我哪里出错了吗?谢谢大家!

import sqlite3

conn = sqlite3.connect('finances.db')

c = conn.cursor()

c.execute("CREATE TABLE IF NOT EXISTS orders (ID INT, DATE TEXT, CHECK TEXT, AMOUNT REAL,DESC TEXT)")

conn.commit()
conn.close()
错误:

line 17, in <module>
    c.execute("CREATE TABLE IF NOT EXISTS orders (ID INT, DATE TEXT, CHECK TEXT, AMOUNT REAL,DESC TEXT)")
sqlite3.OperationalError: near "TEXT": syntax error
第17行,在
c、 执行(“如果不存在订单,则创建表(ID INT、日期文本、支票文本、实际金额、说明文本)”)
sqlite3.error:靠近“文本”:语法错误

CHECK
是SQLite中的保留字。您需要用双引号将其括起来,或者更好地将列的名称更改为其他名称,这样您就不必在以后编写查询时担心这一点

CREATE TABLE IF NOT EXISTS orders (
    ID INT, 
    DATE TEXT, 
    CHK TEXT, 
    AMOUNT REAL,
    DESC TEXT
);
我还反对使用诸如
DATE
DESC
之类的栏目名称;尽管SQLite允许这样做,但它们显然对应于SQL关键字,这使得它们在本质上具有歧义性:

CREATE TABLE IF NOT EXISTS orders (
    ID INT, 
    ORDER_DATE TEXT, 
    CHK TEXT, 
    AMOUNT REAL,
    DESCR TEXT
);
参考文献: