我正在开发一个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创建表的。
请帮助我删除此错误。谢谢。
1条答案
按热度按时间ngynwnxp1#
我不认为mysql会自动添加主键。添加
autoincrement=True
到列语句或者,因为您是直接用sql生成代码,所以使用
更新数据库表时出现问题;主键未设置为自动递增。所以,尝试这个命令实际上奏效了: