将日期值存储到python3中的sqlite表中存储整数值

我被这个错误以及如何解决它所困扰。


背景:我在 SQLite 中构建了一个“Paycheck”表,该表具有日期属性、净工资属性和总工资属性。我在 SQLite 中将date属性设置为date数据类型,并将net和Gross属性设置为integer数据类型。


问题:我遇到了一个问题,当我尝试插入薪水记录时,日期属性将存储为“1994”。问题是,当我创建存储薪水记录的功能时,我在网上看到SQLite 中日期数据类型的日期格式是 yyyy-mm-dd,并且我确保我会以该格式插入日期,但代码会运行良好,但在数据库中,每次我尝试添加记录时,它都会为日期显示“1994”。


以下是所有相关代码:


import sqlite3

import datetime



def date_sql_format():

    """return date in sql DATE format"""

    return str(datetime.datetime.now().strftime("%Y-%m-%d"))



def execute(command: str):

    """Take a sql query and execute it on the database."""

    connect = sqlite3.connect("db.sqlite")

    cursor = connect.cursor()

    cursor.execute(command)

    connect.commit()

    connect.close()



def add_paycheck(date: str, net: float, gross: float):

    """Add a paycheck record to the database."""

    template = f"{date}, {net}, {gross}"

    execute(f"INSERT INTO Paycheck (Date, Net, Gross) VALUES ({template})")


慕斯王
浏览 148回答 1
1回答

凤凰求蛊

将此评估 2020-04-22为算术表达式。答案是 1994 年。这就是这个数字的来源。sqlite内部没有数据类型date。如果您查看sqlite 数据类型 doc的Affinity Name Examples部分,则create table 语句中的typename会产生关联。所以它做数学。DATENUMERIC将日期列的数据类型更改为 TEXT。您可能希望方便地保留sqlite 日期和时间函数文档。
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Go