python - flask-sqlalchemy 怎么设置json格式的字段
问题描述
flask-sqlalchemy 怎么设置json格式的字段
问题解答
回答1:有两种方法:1.sqlalchemy中PickleType可以对应任何python对象.2.可以通过编写方法的方式生成json.
具体代码如下:
#!usr/bin/env python# coding:utf-8from flask import Flaskfrom flask_sqlalchemy import SQLAlchemyapp = Flask(__name__)app.config[’SQLALCHEMY_DATABASE_URI’] = ’mysql://root:psw@localhost/test_json’app.config[’SQLALCHEMY_TRACK_MODIFICATIONS’] = Truedb = SQLAlchemy(app)class Users(db.Model): __tablename__ = ’users’ user_id = db.Column(db.Integer, primary_key=True) user_info = db.Column(db.PickleType) def __repr__(self):return self.user_infoclass Students(db.Model): __tablename__ = ’students’ student_id = db.Column(db.Integer, primary_key=True) student_name = db.Column(db.String(80), unique=True) student_age = db.Column(db.Integer) student_sex = db.Column(db.String(20)) def to_json(self):json_student = { ’student_id’: self.student_id, ’student_name’: self.student_name, ’student_sex’: self.student_sex, ’student_age’: self.student_age}return json_student def __repr__(self):return ’%r’ % self.student_idif __name__ == '__main__': #-----------------------生成----------------------- USER_INFO = {'name':'nisiwa', 'mail':'2222233333@qq.com'} db.create_all() USER = Users(user_info=USER_INFO) STUDENT = Students(student_name='nisiwa', student_age='28', student_sex='male') db.session.add(USER) db.session.add(STUDENT) db.session.commit() #-----------------------调用------------------------ user = Users.query.filter_by(user_id=1).first() student = Students.query.filter_by(student_id=1).first() print ’student:’, student.to_json() print ’user:’, user.user_info
结果如下:
相关文章:
1. mongodb - windows7下mongod无法正常启动2. mysql中的全文索引支持词根检索吗?3. 修改mysql配置文件的默认字符集重启后依然不生效4. MySQL视图count速度优化5. php - 类似Apple官网顶部3级导航该如何设计数据库?6. mysql - 请教一个Java做数据库缓存的问题7. 请问一下各位老鸟 我一直在学习独孤九贱 现在是在tp5 今天发现 这个系列视频没有实战8. Python两个list互换,两种不同的操作结果有差异,原因是什么呢?9. android-studio - Android Studio logcat一闪而过,如何显示出来10. javascript - ueditor引入报错问题

网公网安备