插入时创建一条记录

create a record when insert

如何在用户中创建用户时将用户添加到钱包 Table table 我正在说明如何使用事件侦听用户 table 但是它似乎根本不起作用。

def User(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String)
    sponsor_referral_id = db.Column(db.String)


def Wallet(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String)
    wallet_1 = db.Column(db.Float, default=0.0)
    wallet_2 = db.Column(db.Float, default=0.0)

我试过这个:

@event.listens_for(User, "after_insert")
def create_wallet(mapper, connection, target):
    target.session.add(Wallet(username=target.username))

当我将用户添加到用户 table 时没有任何结果。

我需要有关如何处理此问题的帮助。

也许我错了...但是当您使用 after_insert + session.add() 时,结果可能不一致。我认为在你的情况下最好使用 after_flush。因为flush()把一系列操作(insert, update, delete)一次传递交易。所以你可以在 flush 之后但在 commit:

之前添加一个新的操作
from flask import Flask, jsonify
from flask_sqlalchemy import SQLAlchemy
from sqlalchemy import event


app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = 'postgresql://...blablalba...'
app.config['SQLALCHEMY_ECHO'] = True  # let's check queries
db = SQLAlchemy(app)


class User(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String)
    sponsor_referral_id = db.Column(db.String)


class Wallet(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String)
    wallet_1 = db.Column(db.Float, default=0.0)
    wallet_2 = db.Column(db.Float, default=0.0)


@event.listens_for(db.session, 'after_flush')
def example(session, instance):
    # save new Wallet record if new User
    for rec in session.new:
        if isinstance(rec, User):
            session.add(Wallet(username=rec.username))


@app.route('/')
def test():
    # create a user and check for updates
    db.session.add(User(username='test', sponsor_referral_id='test'))
    db.session.commit()
    user1 = User.query.first()
    user1.username = 'new name'
    db.session.commit()

    # create one more user
    db.session.add(User(username='test2', sponsor_referral_id='test2'))
    db.session.commit()
    return jsonify({'wallets': len(Wallet.query.all()), 'users': len(User.query.all())})


db.create_all()

运行服务器,打开http://localhost:5000/查看日志:

2021-07-16 17:48:33,992 INFO sqlalchemy.engine.Engine BEGIN (implicit)
2021-07-16 17:48:33,994 INFO sqlalchemy.engine.Engine INSERT INTO "user" (username, sponsor_referral_id) VALUES (%(username)s, %(sponsor_referral_id)s) RETURNING "user".id
2021-07-16 17:48:33,994 INFO sqlalchemy.engine.Engine [generated in 0.00023s] {'username': 'test', 'sponsor_referral_id': 'test'}
2021-07-16 17:48:33,997 INFO sqlalchemy.engine.Engine INSERT INTO wallet (username, wallet_1, wallet_2) VALUES (%(username)s, %(wallet_1)s, %(wallet_2)s) RETURNING wallet.id
2021-07-16 17:48:33,998 INFO sqlalchemy.engine.Engine [generated in 0.00030s] {'username': 'test', 'wallet_1': 0.0, 'wallet_2': 0.0}
2021-07-16 17:48:33,999 INFO sqlalchemy.engine.Engine COMMIT


2021-07-16 17:48:34,004 INFO sqlalchemy.engine.Engine BEGIN (implicit)
2021-07-16 17:48:34,006 INFO sqlalchemy.engine.Engine SELECT "user".id AS user_id, "user".username AS user_username, "user".sponsor_referral_id AS user_sponsor_referral_id 
FROM "user" 
 LIMIT %(param_1)s
2021-07-16 17:48:34,007 INFO sqlalchemy.engine.Engine [generated in 0.00026s] {'param_1': 1}
2021-07-16 17:48:34,010 INFO sqlalchemy.engine.Engine UPDATE "user" SET username=%(username)s WHERE "user".id = %(user_id)s
2021-07-16 17:48:34,010 INFO sqlalchemy.engine.Engine [generated in 0.00020s] {'username': 'new name', 'user_id': 1}
2021-07-16 17:48:34,010 INFO sqlalchemy.engine.Engine COMMIT


2021-07-16 17:48:34,012 INFO sqlalchemy.engine.Engine BEGIN (implicit)
2021-07-16 17:48:34,012 INFO sqlalchemy.engine.Engine INSERT INTO "user" (username, sponsor_referral_id) VALUES (%(username)s, %(sponsor_referral_id)s) RETURNING "user".id
2021-07-16 17:48:34,013 INFO sqlalchemy.engine.Engine [cached since 0.01892s ago] {'username': 'test2', 'sponsor_referral_id': 'test2'}
2021-07-16 17:48:34,014 INFO sqlalchemy.engine.Engine INSERT INTO wallet (username, wallet_1, wallet_2) VALUES (%(username)s, %(wallet_1)s, %(wallet_2)s) RETURNING wallet.id
2021-07-16 17:48:34,014 INFO sqlalchemy.engine.Engine [cached since 0.01685s ago] {'username': 'test2', 'wallet_1': 0.0, 'wallet_2': 0.0}
2021-07-16 17:48:34,015 INFO sqlalchemy.engine.Engine COMMIT

看起来像你需要的。