sqlalchemy.exc.integrityerror-mysql-主键在数据库中自动递增和存储时出错

nvbavucw  于 2021-06-21  发布在  Mysql
关注(0)|答案(1)|浏览(381)

我正在开发一个sqlalchemy应用程序并使用mysql数据库。我有一个表单,从中接收要存储在名为“intent”的数据库表中的数据。该表有两列:intent\u id和intent\u name。
下面是我的sqlalchemy模型的代码:

from flask_sqlalchemy import SQLAlchemy

db = SQLAlchemy()

class Intent(db.Model):
  __tablename__ = 'intent'
  intent_id = db.Column('intent_id', db.Integer, primary_key=True)
  intent_name = db.Column(db.String(250))

下面是我的文件的代码:

from flask import Flask, render_template, request, session, redirect, url_for
from models import db, Intent, Sentence

app = Flask(__name__)

app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://root:@localhost/test'

app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
db.init_app(app)

@app.route("/", methods = ['POST', 'GET'])
def index():
    if request.method == 'POST':
        intentobj = Intent(intent_name = request.form['intent'])

        db.session.add(intentobj)
        db.session.commit()

        return render_template("index.html", intent_data = Intent.query.all())
    elif request.method == 'GET':
        return render_template("index.html", intent_data = Intent.query.all())

我得到这个错误:

sqlalchemy.exc.IntegrityError: (_mysql_exceptions.IntegrityError) (1364, "Field 'intent_id' doesn't have a default value") [SQL: 'INSERT INTO intent (intent_name) VALUES (%s)'] [parameters: ('def',)]

当我创建数据库表类的对象时,我只在其中存储一个名称(如上所述)。我希望intent\u id自动递增并存储在数据库中,因为它是一个主键,但我猜它不是这样工作的。
请注意,我是使用phpmyadmin而不是通过python创建表的。
请帮助我删除此错误。谢谢。

ngynwnxp

ngynwnxp1#

我不认为mysql会自动添加主键。添加 autoincrement=True 到列语句

intent_id = db.Column('intent_id', db.Integer, primary_key=True, autoincrement=True)

或者,因为您是直接用sql生成代码,所以使用

intent_id int NOT NULL PRIMARY_KEY AUTO_INCREMENT

更新数据库表时出现问题;主键未设置为自动递增。所以,尝试这个命令实际上奏效了:

ALTER TABLE document MODIFY COLUMN document_id INT auto_increment

相关问题