flask系列四之SQLAlchemy(二)表关系
一、SQLAlchemy外键约束
1.创建外键约束表结构
目标:建立两个表“用户表(user)”和“问题表( question)”,其中问题表中的作者id是是用户表的id即外键的关系。(一个用户可以有多个问题)
Python语句
(1)用户类
class User(db.Model):
__tablename__ = 'user'#用户表
id=db.Column(db.Integer,primary_key=True, autoincrement=True)
telephone=db.Column(db.String(11), nullable=False)
username=db.Column(db.String(50), nullable=False)
password=db.Column(db.String(100), nullable=False)
confirmPassword = db.Column(db.String(100), nullable=False)
(2)问题类
from datetime import datetime
class Question(db.Model):
__tablename__ = 'question'#问题表
id = db.Column(db.Integer, primary_key=True, autoincrement=True)
title = db.Column(db.String(100), nullable=False)
content = db.Column(db.Text, nullable=False)
# now()获取服务器第一次允许的时间
# now 是每次创建一个模型的时候都获取当前的时间
create_time = db.Column(db.DateTime, default=datetime.now)
# 定义外键 ---外键指定--使用表名
author_id = db.Column(db.Integer, db.ForeignKey('user.id')) #外键依赖--使用模型名称(类名称)
# backref表达的是:一个author对应多个questions
author = db.relationship('User', backref=db.backref('questions'))# 可以使用:authour.questions 得出当前作者的所有问题
2.数据库添加用户和问题
1.要想添加一个问题,因为问题必须依赖用户而存在,所以首先要先添加一个用户并登录成功。
userObj = User(telephone=‘xxxx’, username='xx', password='xx',confirmPassword='xx')
db.session.add(userObj)
db.session.commit()
2.在用户已经登录的的基础上添加一个问题。
from decorations import login_required
@app.route('/question/', methods=["GET", "POST"])
@login_required
def question():
if request.method == "GET":# 加载页面
return render_template("question.html")
else:# 接收表单提交
title = request.form.get("title")
content = request.form.get("content")
question = Question(title=title, content=content)
user_id = session.get("user_id")# user_id:登录用户的id通过session记录
user = User.query.filter(User.id == user_id).first()
question.author = user
db.session.add(question)
db.session.commit()
return redirect(url_for('index'))
注意此处使用装饰器login_required来处理是否登录问题:
decorations.py中:
from functools import wraps
from flask import session,redirect,url_for # 登录限制装饰器
def login_required(func):
@wraps(func)
def wrapper(*args, **kwargs):
if session.get('user_id'):
return func(*args, **kwargs)
else:
return redirect(url_for("login"))
return wrapper
使用装饰器后,若用户没有登录,需要添加问题则会首先跳转到登录页面,登录后才能操作。
3.查找问题的作者
question = Question(title=title, content=content)
user_id = session.get("user_id")
user = User.query.filter(User.id == user_id).first()
question.author = user# 问题的作者
db.session.add(question)
db.session.commit()
4.列出某个作者写过的所有问题
利用反向引用(backref)来,根据作者名字,查找出作者写过的所有文章。
# 使用的方法
user = Users.query.filter(Users.username=='xxx').first()
result = user.questions# 作者添加的所有问题
for question in result:
pass
二、多对多关系讲解
(1)多对多的关系,需要通过一个中间表进行关联。
(2)中间表,不能通过class的方式实现,只能通过db.Table的方式实现。
(4)设置关联:tags = db.relationship('Tag',secondary=article_tag,backref=db.backref('articles'))需要使用一个关键字参数secondary=中间表 来进行关联。
待续。。。可以参考:http://blog.csdn.net/qq_28877125/article/details/77664575
flask系列四之SQLAlchemy(二)表关系的更多相关文章
- flask系列四之SQLAlchemy
一.SQLAlchemy简介 (1)flask_sqlalchemy是一套ORM框架. (2)ORM(Object Relationship Mapping):模型关系映射 (3)ORM的好处:可以让 ...
- 单元测试系列之七:Sonar 数据库表关系整理一(rule相关)
更多原创测试技术文章同步更新到微信公众号 :三国测,敬请扫码关注个人的微信号,感谢! 原文链接:http://www.cnblogs.com/zishi/p/7510072.html 简介:Sonar ...
- 单元测试系列之八:Sonar 数据库表关系整理一(续)
更多原创测试技术文章同步更新到微信公众号 :三国测,敬请扫码关注个人的微信号,感谢! 简介:Sonar平台是目前较为流行的静态代码扫描平台,为了便于使用以及自己二次开发,有必要对它的数据库结构进行学习 ...
- flask的orm框架(SQLAlchemy)-创建表
# 转载请留言联系 ORM 是什么? ORM,Object-Relation Mapping.意思就是对象-关系映射.ORM 主要实现模型对象到关系数据库数据的映射. 优点 : 只需要面向对象编程, ...
- Flask系列(四)Flask实现简单页面登陆
from flask import Flask,render_template,request,redirect,session app = Flask(__name__,template_folde ...
- C#中的函数式编程:递归与纯函数(二) 学习ASP.NET Core Razor 编程系列四——Asp.Net Core Razor列表模板页面
C#中的函数式编程:递归与纯函数(二) 在序言中,我们提到函数式编程的两大特征:无副作用.函数是第一公民.现在,我们先来深入第一个特征:无副作用. 无副作用是通过引用透明(Referential ...
- SQLAlchemy(三):外键、连表关系
SQLAlchemy03 /外键.连表关系 目录 SQLAlchemy03 /外键.连表关系 1.外键 2.ORM关系以及一对多 3.一对一的关系 4.多对多的关系 5.ORM层面的删除数据 6.OR ...
- RX系列四 | RxAndroid | 加载图片 | 提交表单
RX系列四 | RxAndroid | 加载图片 | 提交表单 说实话,学RxJava就是为了我们在Android中运用的更加顺手一点,也就是RxAndroid,我们还是先一步步来,学会怎么去用的比较 ...
- BootStrap 智能表单系列 四 表单布局介绍
表单的布局分为自动布局和自定义布局两种: 自动布局就是根据配置项中第二级配置项中数组的长度来自动使用不同的bootstrap栅格,通过设置autoLayout为true可以实现自动布局 自动以布局就是 ...
随机推荐
- 【lightoj-1026】Critical Links(桥)
题意: 给出无向图,求桥的模板题. #include <bits/stdc++.h> using namespace std; ; int dfn[N], low[N];//时间戳;low ...
- 【51nod-1596】搬货物
现在有n个货物,第i个货物的重量是 2wi .每次搬的时候要求货物重量的总和是一个2的幂.问最少要搬几次能把所有的货物搬完. 样例解释: 1,1,2作为一组. 3,3作为一组. Input 单组测试数 ...
- 【zzulioj-1676】与同学比身高(综合)
题目链接: http://acm.zzuli.edu.cn/problem.php?id=1676 题目描述 新学年开学了,学校又迎来了一批新同学,已知部分同学之间的身高关系,请列出可推断出的同学之间 ...
- python考试
py4测试题 1.8<<2等于?322.通过内置函数计算5除以2的余数 divmod(5,2)3.s=[1,"h",2,"e",[1,2,3],&q ...
- 解决PKIX问题:unable to find valid certification path to requested target
第一步:执行方式:java InstallCert hostname eg:java InstallCert www.cebbank.com 第二步:然后输 ...
- svn: E220001: 遇到不可读的路径;拒绝访问。
在客户端试图 svn merge 总是报svn: E220001: 遇到不可读的路径:拒绝访问.这个错误 提示 : SVN 遇到不可读的路径:拒绝访问. 英文是: Unreadable path en ...
- linux 权限之所有者所属组
linux 如何改变文件属性与权限 我们知道档案权限对于一个系统的安全重要性,也知道档案的权限对于使用者与群组的相关性, 那如何修改一个档案的属性与权限呢? 我们这里介绍几个常用于群组.拥有者.各种身 ...
- BZOJ - 2957 (分块/线段树)
题目链接 本质是维护斜率递增序列. 用分块的方法就是把序列分成sqrt(n)块,每个块分别用一个vector维护递增序列.查询的时候遍历所有的块,同时维护当前最大斜率,二分找到每个块中比当前最大斜率大 ...
- HihoCoder 1183 : 连通性一·割边与割点(模板)
连通性一·割边与割点 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 还记得上次小Hi和小Ho学校被黑客攻击的事情么,那一次攻击最后造成了学校网络数据的丢失.为了避免再次 ...
- iOS6和iOS7代码的适配(6) —— NSLocalizedString
我们的应用都是需要国际化的,字符串也是重要的一环.一般来说,我们是通过一个string资源文件来实现这个目的的,我们需要支持几种语言,就把这个文件本地化多少次.代码中需要用NSLocalizedStr ...