一、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(二)表关系的更多相关文章

  1. flask系列四之SQLAlchemy

    一.SQLAlchemy简介 (1)flask_sqlalchemy是一套ORM框架. (2)ORM(Object Relationship Mapping):模型关系映射 (3)ORM的好处:可以让 ...

  2. 单元测试系列之七:Sonar 数据库表关系整理一(rule相关)

    更多原创测试技术文章同步更新到微信公众号 :三国测,敬请扫码关注个人的微信号,感谢! 原文链接:http://www.cnblogs.com/zishi/p/7510072.html 简介:Sonar ...

  3. 单元测试系列之八:Sonar 数据库表关系整理一(续)

    更多原创测试技术文章同步更新到微信公众号 :三国测,敬请扫码关注个人的微信号,感谢! 简介:Sonar平台是目前较为流行的静态代码扫描平台,为了便于使用以及自己二次开发,有必要对它的数据库结构进行学习 ...

  4. flask的orm框架(SQLAlchemy)-创建表

    # 转载请留言联系 ORM 是什么? ORM,Object-Relation Mapping.意思就是对象-关系映射.ORM 主要实现模型对象到关系数据库数据的映射. 优点 : 只需要面向对象编程, ...

  5. Flask系列(四)Flask实现简单页面登陆

    from flask import Flask,render_template,request,redirect,session app = Flask(__name__,template_folde ...

  6. C#中的函数式编程:递归与纯函数(二) 学习ASP.NET Core Razor 编程系列四——Asp.Net Core Razor列表模板页面

    C#中的函数式编程:递归与纯函数(二)   在序言中,我们提到函数式编程的两大特征:无副作用.函数是第一公民.现在,我们先来深入第一个特征:无副作用. 无副作用是通过引用透明(Referential ...

  7. SQLAlchemy(三):外键、连表关系

    SQLAlchemy03 /外键.连表关系 目录 SQLAlchemy03 /外键.连表关系 1.外键 2.ORM关系以及一对多 3.一对一的关系 4.多对多的关系 5.ORM层面的删除数据 6.OR ...

  8. RX系列四 | RxAndroid | 加载图片 | 提交表单

    RX系列四 | RxAndroid | 加载图片 | 提交表单 说实话,学RxJava就是为了我们在Android中运用的更加顺手一点,也就是RxAndroid,我们还是先一步步来,学会怎么去用的比较 ...

  9. BootStrap 智能表单系列 四 表单布局介绍

    表单的布局分为自动布局和自定义布局两种: 自动布局就是根据配置项中第二级配置项中数组的长度来自动使用不同的bootstrap栅格,通过设置autoLayout为true可以实现自动布局 自动以布局就是 ...

随机推荐

  1. 【nyoj-1274】信道安全(SPFA)

    题目链接:http://acm.nyist.edu.cn/JudgeOnline/problem.php?pid=1274 题目描述 Alpha 机构有自己的一套网络系统进行信息传送.情报员 A 位于 ...

  2. linux时间管理 之 jiffies

    1.jiffies 又称时钟滴答,是一个全局变量,它的值在系统引导的时候初始化为0,在时钟中断初始化完成后,每次时钟中断发生,在时钟中断处理例程中都会将jiffies的值 +1. jiffies_64 ...

  3. Http权威指南(TCP连接)

    1.HTTP请求的过程 世界上几乎所有的HTTP通信都是由TCP/IP承载的,当发生HTTP请求时,实际上经过了以下几个步骤: ①浏览器从请求的URL中解析主机名 ②浏览器查询这个主机名的IP地址 ③ ...

  4. git配置ssh key并从github.com拉取repos

    一.配置ssh key 1. 进入当前用户目录cd ~2. 生成ssh keyssh-keygen -t rsa -C "ABC@qq.com"ABC@qq.com账号必须是你登录 ...

  5. canvas 绘制环形进度条

    结果: 代码: <!DOCTYPE html> <html> <head lang="en"> <meta charset="U ...

  6. [转]优化Flash性能

    原文:http://www.adobe.com/devnet/flash/articles/optimizing-flash-performance.html 翻译:http://bbs.9ria.c ...

  7. docx转doc时,防止公式被转成图片的解决办法

    编辑社回复需要doc(Word 97-2003)格式的文档,可是将docx(Word 2007+)另存为doc格式时,发现公式被转成了图片.其实,最简单的办法就是,打个电话过去给编辑社:“大爷,拜托您 ...

  8. HDU - 6395:Sequence (分块+矩阵)

    题面太丑了,就不复制了. 题意:F1=A: F2=B: Fn=D*Fn-1+C*Fn-2+P/i:求Fn. 思路:根据P/i的值划分区间,每个区间矩阵求. 带常数的矩阵: #include<bi ...

  9. PS更换证件照颜色

    PS是我们经常使用的设计软件,在生活中使用的范围也很广,但是对于普通的用户来说,也就是平时给自己的照片美化一下,还有就是做一些证件照.今天和大家分享的是更改证件照的颜色,网上可能有很多,但是个人感觉都 ...

  10. 由于出现操作系统错误 3,进程无法读取文件D:\XXXX\X.pre (源: MSSQL_REPL,错误号: MSSQL_REPL20024)

    最近着手做SqlServer2008的订阅发布,起初使用推送订阅很顺利,后来改成请求订阅出现了以下问题,折腾好长时间终于搞定,留下此文备日后查阅,或供遇相同问题的道友参考: 首先阐述以下问题: 1. ...