SQLAlchemy是Python中比较优秀的orm框架,在SQLAlchemy中定义了多种数据库表的对应关系,

其中一对多是一种比较常见的关系。利用flask sqlalchemy实现一对多的关系如下:

1. 建立数据库的模型

在本次试验中建立三个表: user, phone ,atttr。user 和phone, phone 和atttr均为一对多的关系。实现如下:

#!/usr/bin/env python
# -*- coding: utf-8 -*- from flask import Flask
from flask.ext.sqlalchemy import SQLAlchemy app = Flask(__name__) # 配置数据库
app.config[
'SQLALCHEMY_DATABASE_URI'] = \
"mysql://root: root@127.0.0.1/test?charset=utf8"
db = SQLAlchemy(app) # 建立user表
class Usr(db.Model):
__tablename__ = 'usr'
id = db.Column(db.Integer, primary_key=True)
usrname = db.Column(db.String(80), unique=True)
email = db.Column(db.String(120), unique=True)
phone = db.relationship('Phone', backref='user', lazy='dynamic') def __init__(self, username, email):
self.usrname = username
self.email = email class Phone(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(20))
factory = db.Column(db.String(20))
userId = db.Column(db.Integer, db.ForeignKey('usr.id'))
attr = db.relationship(
'Atttr', backref='phone', lazy='dynamic') def __init__(self, name, factory, userId):
self.name = name
self.factory = factory
self.userId = userId class Atttr(db.Model):
id = db .Column(db.Integer, primary_key=True)
color = db.Column(db.String(20))
price = db.Column(db.String(20))
macId = db.Column(db.Integer, db.ForeignKey('phone.id')) def __init__(self, color, price, macId):
self.color = color
self.price = price
self.macId = macId db.create_all()

  user表和phone表的一对多的关系通过下面语句确定:

phone = db.relationship('Phone', backref='user', lazy='dynamic')

  其中rrealtionship描述了user和phone的关系。在此文中,第一个参数为对应参照的类"Phone";

第二个参数backref为类Phone申明新属性的方法;第三个参数lazy决定了什么时候SQLALchemy从

数据库中加载数据。

2. 构造api获取数据资源

  注意:在获取资源之前,先向数据库中写入测试数据

#!usr/bin/env pyhton
# -*- coding: utf-8 -*- from flask import Flask
from flask.ext.restful import reqparse, Api, Resource
from model import * app = Flask(__name__)
api = Api(app) def to_json(model):
""" Returns a JSON representation of an SQLAlchemy-backed object. """
json = {}
# json['fields'] = {}
# json['pk'] = getattr(model, 'id')
for col in model._sa_class_manager.mapper.mapped_table.columns:
# json['fields'][col.name] = getattr(model, col.name)
json[col.name] = getattr(model, col.name)
# return dumps([json])
return json def to_json_list(model_list):
json_list = []
for model in model_list:
json_list.append(to_json(model))
return json_list def message(record):
if record:
return to_json(record), 200
return {"message": "not exit"}, 400 class userResource(Resource): def get(self, id):
record = Usr.query.filter_by(id=id).first()
return to_json_list(record.phone.first().phone) def put(self, id):
parser = reqparse.RequestParser()
parser.add_argument('username', type=str)
args = parser.parse_args(strict=True)
record = Usr.query.filter_by(id=id).first()
if record:
record.username = args['username']
db.session.commit()
return {"status": "updated"}, 201
return {"message": "not exit"}, 400 def delete(self, id):
record = Usr.query.filter_by(id=id).first()
if record:
db.session.delete(record)
db.session.commit()
return {"status": "deleted"}, 204
return {"message": "not exit"}, 400

  class AtrrResource(Resource):

    def get(self, id):
    record = Atttr.query.filter_by(id=id).first()
    return message(record.phone.user)

api.add_resource(userResource, '/v1.0/user/<id>')
  api.add_resource(usrList, '/v1.0/user', '/v1.0/user/')

api.add_resource(AtrrResource, '/v1.0/atrr/<id>')

 if '__name__' == '__main__' :

   app.run(DEBUG=True)

通过在浏览器中输入url: 127.0.0.1:5000/v1.0/user/1可以获得某用户的某种类型手机的所有属性。

主要为get函数,其通过三层访问,即可得到相关的信息。当然还可以通过查询某一手机的颜色获取其

用户的信息,如Atttr get所示。

参考资料:

[1] http://docs.jinkan.org/docs/flask-sqlalchemy/models.html#id3

flask SQLAlchemy中一对多的关系实现的更多相关文章

  1. python3 + flask + sqlalchemy +orm(3):多对多关系

    一篇文章有多个tag,一个tag也可以属于多篇文章,文章和tag存在多对多关系 config.py DEBUG = True #dialect+driver://root:1q2w3e4r5t@127 ...

  2. EF中一对多的关系中,用单字段保存ID拼接字符串

    model.SubjectTerms = model.SelectedSubjectTerm.Trim(',').Split(',').ToList().Select(x => new Subj ...

  3. jeecg中一对多的关系映射

    1.首先看一张前端页面: 有一张主表和3张子表,显示这3张子表的代码如下 <t:tabs id="tt" iframe="false" tabPositi ...

  4. 用SQLAlchemy创建一对多,多对多关系表

    多对多关系表的创建: 如果建立好多对多关系后,我们就可以通过关系名进行循环查找,比如laowang = Teacher.query.filter(Teacher.name=='laowang').fi ...

  5. SQLALchemy中关于复杂关系表模型的映射处理

    映射在第五步,我们还是一步一步来哈 一. 关系介绍 举一个比较经典的关系,部门与员工(以下是我的需求情况,算是把该有的关系都涉及到了) 1.每个部门会有很多成员(这里排除一个成员属于多个部门的情况) ...

  6. java类集开发中一对多和多对多的关系的实现

    摘自<java开发实战经典>李兴华.著 一对多的关系 一个学校可以包含多个学生,一个学生属于一个学校,那么这就是一个典型的一对多关系,此时就可以通过类集进行关系的表示. 在定义Studen ...

  7. python3 + flask + sqlalchemy +orm(2):数据库中添加表

    往数据库中添加一张保存文章的表,表明为article,字段有id,title,content 同样一个配置文件:config.py DEBUG = True #dialect+driver://roo ...

  8. 12.翻译系列:EF 6 中配置一对多的关系【EF 6 Code-First系列】

    原文链接:https://www.entityframeworktutorial.net/code-first/configure-one-to-many-relationship-in-code-f ...

  9. day95:flask:SQLAlchemy数据库查询进阶&关联查询

    目录 1.数据库查询-进阶 1.常用的SQLAlchemy查询过滤器 2.常用的SQLAlchemy查询结果的方法 3.filter 4.order_by 5.count 6.limit&of ...

随机推荐

  1. Linux中修改环境变量导致大量命令不可用的解决办法

    如果搞死环境变量别慌张.因为ls等命令都不能使用了,所以先找到/usr/bin/目录 使用./sudo su命令获取root权限 然后在进入/etc目录 利用vim profile命令 修改profi ...

  2. 前端优化之图片延迟加载(lazyload.js)

    要想缩短首屏加载时间,思路一般是减少http请求次数和降低每次的请求量.本文中使用现成的lazyload.js插件,文末会放出下载地址. lazyload.js可以实现图片分批次加载,不是一次性加载完 ...

  3. python 异常处理、文件常用操作

    异常处理 http://www.jb51.net/article/95033.htm 文件常用操作 http://www.jb51.net/article/92946.htm

  4. 初始通过 FastClick.notNeeded 方法判断是否需要做后续相关处理

    其实前面几篇文章大家都遇到一些错误,很多时候呢,我并没有直接回复解决方案,不是LZ不想告诉大家,如果不想那就不写这个了,估计博客园啊CSDN啊那么多写博客的,很少有人把现用框架分享出来,既然分享就毫不 ...

  5. cookie多次点赞效果

    <!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>& ...

  6. MySql学习 (一) —— 基本数据库操作语句、三大列类型

    注:该MySql系列博客仅为个人学习笔记. 在使用MySql的时候,基本都是用图形化工具,如navicat.最近发现连最基本的创建表的语法都快忘了... 所以,想要重新系统性的学习下MySql,为后面 ...

  7. The different of mouseover and mouseenter

    l论事件onmouseover 和 onmouseenter:同类比较onmouseout 和 onmouseleave; 使用onmouseover时,鼠标除了被设置事件的元素,还会触发其子元素: ...

  8. 160个crackme-之Acid burn.exe

    工具: Ollydbg(OD) 中文版 运行: 我们拿到一个小程序时,总要看看它到底有什么功能,或者说它阻碍了我们什么,也就是寻找突破口! 这就是程序运行后的主界面 我们进入Serial/Name后, ...

  9. 关于java 定时器的使用总结

    直接上代码,代码中有注释(代码中还有一些本人的其他测试,读者可以忽略不计).读者在代码中发现了bug,欢迎指正. package j2se.system.test; import java.text. ...

  10. 入门struts2.0

    框架是什么? 1.应用程序的半成品. 2.可重用行公共的结构. 3.按一定规则组织的一组组件. model2 其实并不是一种全新的概念,很对人指出model2其实正好是经典的"模型(mode ...