表单数据不使用最新条目刷新

2024-04-23 10:36:08 发布

您现在位置:Python中文网/ 问答频道 /正文

当我在customer表中添加新客户并访问AddOrderForm表单时,我不会在选择。但是在服务器重新启动时,我可以在选择中找到新客户有吗为什么?你知道吗

客户表

class Customer(db.Model):
     id = db.Column(db.Integer, primary_key=True)
     email = db.Column(db.String(120), unique=True)
     mobile_num = db.Column(db.String(13), unique=True)
     name = db.Column(db.String(120))
     marketing_source = db.Column(db.String(120))
     date_of_birth = db.Column(db.DateTime)
     gender = db.Column(db.String(13))
     store_id = db.Column(db.Integer, db.ForeignKey('store.id'))

     def __init__(self,email,mobile_num,name,marketing_source,date_of_birth, gender,store_id):
         self.email = email
         self.mobile_num = mobile_num
         self.name = name
         self.marketing_source = marketing_source
         self.date_of_birth = date_of_birth
         self.gender = gender
         self.store_id = store_id
     def __repr__(self):
          return '%r, %s ' % (self.name.encode('utf-8'), self.mobile_num)

添加订单

class AddOrderForm(Form):
    order_id  = TextField('Website Order Id', [validators.length(min=4, max=120)])
    item_name = TextField('Item Name', [validators.length(min=4, max=120)])
    item_cost = DecimalField('Item Cost' , [validators.Required()])
    custmer_id = SelectField('Customer',coerce=int,choices= convert_list_wtforms_choices(Customer.query.all()))
    order_category = SelectField('Order Category',coerce=int,choices=[(1,'Mobiles'), (2,'Clothing')])
    linq_shipping_cost =  DecimalField('Linq Shipping Cost' , [validators.Required()])
    website_shipping_cost = DecimalField('Website Shipping Cost' , [validators.Required()])
    advance_amount = DecimalField('Advance Amount' , [validators.Required()])
    website = SelectField('Website', coerce=int,choices=[(1,'Amazon'), (2,'Flipkart')] )
    other = TextField('Any Other Information')

从视图访问表单时,我没有在customer\u id选项中获得最新添加的客户。有办法解决这个问题吗?你知道吗


Tags: storenameselfidsourcedbdatestring
1条回答
网友
1楼 · 发布于 2024-04-23 10:36:08

在定义表单时,只需设置一次选项。相反,每次实例化表单时都要重新选择它们。你知道吗

class AddOrderForm(Form):
    customer_id = SelectField('Customer', coerce=int)

    def __init__(self, *args, **kwargs):
        super(AddOrderForm, self).__init__(*args, **kwargs)
        self.customer_id.choices = convert_list_wtforms_choices(Customer.query.all())

相关问题 更多 >