low*_*e00 3 python sqlalchemy flask flask-sqlalchemy
我第一次尝试 ORM,试图了解它是如何工作的,但遇到了一些挑战:
我想做的是,将 API 中的 JSON 放入 SQLAlchemy 模型中,然后将所有条目批量插入到我的数据库中。但由于某种原因,我在 SQLAlchemy 中遇到错误。
根据我对错误的理解,在某个时间点,当将数据分配给我的模型时,它被转换为字典,而我认为它应该是class objects.
我的预期结果是成功插入所有条目。有人能帮我弄清楚我可能做错了什么吗?
欣赏。*
错误
sqlalchemy.exc.ProgrammingError:
(mysql.connector.errors.ProgrammingError)
Failed processing pyformat-parameters;
Python 'dict' cannot be converted to a MySQL type
Run Code Online (Sandbox Code Playgroud)
JSON:
{
"all_orders": [
{
"id": 456215587,
"created_at": "2018-11-04T23:18:18-02:00",
"order_number": null,
},
{
"id": null,
"created_at": "2018-11-04T23:18:18-02:00",
"order_number": 1982,
}]
}
Run Code Online (Sandbox Code Playgroud)
功能
def update_orders(all_orders):
cursor = db_cursor()
session = db_session()
orders_entries = []
for orders in all_orders:
order_id = orders.get("id", {})
order_number = orders.get("order_number", {})
created_at = orders.get("created_at", {})
new_entry = SalesOrders(order_id=order_id,
order_number=order_number,
created_at=created_at)
orders_entries.append(new_entry)
session.add_all(orders_entries)
session.commit()
Run Code Online (Sandbox Code Playgroud)
该模型
class SalesOrders(db.Model):
__tablename__ = 'sales_orders'
id = Column(Integer, nullable=False, index=True)
order_id = Column(String(50), primary_key=True, server_default=text("''"))
order_number = Column(String(50))
created_at = Column(String(100))
Run Code Online (Sandbox Code Playgroud)
编辑以使其可验证。函数 .get() 正在创建一个字典,而不是一个None对象,并且 SQLAlchemy 无法插入 Python 字典。
使用该get()函数时,SQLAlchemy 会获取一个字典,这在 SQL Insert 函数中是不需要的,从而产生错误。要使其工作,只需传递None对象而不是{}.
import os
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from sqlalchemy import *
basedir = os.path.abspath(os.path.dirname(__file__))
app = Flask(__name__)
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = True
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///' + os.path.join(basedir, 'main.db')
db = SQLAlchemy(app)
data = {
"all_orders": [
{
"id": 456213548,
"created_at": "2018-11-04T23:18:18-02:00",
"number": null
},
{
"id":4562222222,
"created_at": "2018-11-04T23:18:18-02:00",
"number": 1982,
}
]
}
class SalesOrders(db.Model):
__tablename__ = 'sales_orders'
order_id = db.Column(db.String(50), primary_key=True, server_default='')
order_number = db.Column(db.String(50))
created_at = db.Column(db.String(50))
def update_orders(data):
orders_entries = []
for orders in data["all_orders"]:
new_entry = SalesOrders(order_id=orders['id'],
order_number=orders['number'])
orders_entries.append(new_entry)
db.session.add_all(orders_entries)
db.session.commit()
if __name__ == "__main__":
app.run(debug=True)
Run Code Online (Sandbox Code Playgroud)
例子:
>>> import app
>>> from app import *
>>> data
{'all_orders': [{'id': 456213548, 'created_at': '2018-11-04T23:18:18-02:00', 'number': 1982}, {'id': 4562222222, 'created_at': '2018-11-04T23:18:18-02:00', 'number': 1982}]}
>>> update_orders(data)
>>> SalesOrders.query.all()
[<SalesOrders 456213548>, <SalesOrders 4562222222>]
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
17491 次 |
| 最近记录: |