1 关系映射
1 多对多
1 什么是多对多
A表中的一条数据可以与B表中任意多条数据相关联
B表中的一条数据可以与A表中任意多条数据相关联
2 实现
在数据库中使用第三张表(关联表)
在编程语言中,可以不编写对应的实体类
1 创建第三张表
student_course = db.Table(
'student_course',# 在数据库中的表名
db.Column('id',db.Integer,primary_key = True),
db.Column('student_id',db.Integer,db.ForeignKey('student.id')),
db.Column('course_id,db.Integer,db.ForeignKey('course.id'))
)
from flask import Flask,render_template,request
from flask_sqlalchemy import SQLAlchemy app = Flask(__name__)
db = SQLAlchemy(app)
app.config['SQLALCHEMY_DATABASE_URI']= 'mysql+pymysql://root:liu@176.215.155.241:3306/flask' # 创建连接实例
app.config['SQLALCHEMY_COMMIT_ON_TEARDOWN'] = True #自动提交 class Course(db.Model):
__tablename__='course'
id = db.Column(db.Integer,primary_key=True)
cname = db.Column(db.String(30),nullable=True)
#增加关联属性和反向引用关系
# 关联属性在course对象中通过哪个属性能够得到对应的所有的teacher
#反向引用关系:在teacher对象中通过哪个属性能找到它对应的course
teachers = db.relationship('Teacher',backref ='course',lazy ='dynamic') def __init__(self,name):
self.cname=name def __repr__(self):
return '<Coure:%r>'%self.cname class Teacher(db.Model):
__tablename__='teacher'
id = db.Column(db.Integer,primary_key=True)
tname = db.Column(db.String(30),nullable=True)
tage = db.Column(db.Integer)
course_id = db.Column(db.Integer,db.ForeignKey('course.id'))
# 增加关联属性以及反向引用
student = db.relationship('Student',backref = 'teacher',lazy='subquery')
wife = db.relationship('Wife',backref='teacher',uselist=False) def __init__(self,name,age,course_id):
self.tname=name
self.tage=age
self.course_id=course_id
def __repr__(self):
return '<Teacher %r>'%self.name class Wife(db.Model):
__tablename__='wife'
id=db.Column(db.Integer,primary_key=True)
wname =db.Column(db.String(30))
wage = db.Column(db.Integer)
#增加一个列(外键):表示引用自Teacher表的主键
teacher_id = db.Column(db.Integer,db.ForeignKey('teacher.id'))
def __init__(self,wname,wage):
self.wname = wname
self.wage = wage def __repr__(self):
return '<Wife %r>'%self.wname class Student(db.Model):
__tablename__='student'
id = db.Column(db.Integer,primary_key=True)
sname = db.Column(db.String(10))
sage = db.Column(db.Integer)
steacher = db.Column(db.Integer,db.ForeignKey('teacher.id'))
courses = db.relationship('Course',
secondary='student_course',
lazy = 'dynamic',
backref=db.backref('students', lazy='dynamic'))
teachers = db.relationship('Teacher',secondary ='student_teacher',
lazy = 'dynamic',
backref = db.backref('teachers',lazy ='dynamic'))
def __repr__(self):
return '<student %s>'%self.sname student_course = db.Table(
'student_course',
db.Column('id',db.Integer,primary_key=True),
db.Column('student_id',db.Integer,db.ForeignKey('student.id')),
db.Column('course_id',db.Integer,db.ForeignKey('course.id'))
) student_teacher = db.Table(
'student_teacher',
db.Column('id',db.Integer,primary_key=True),
db.Column('student_id',db.Integer,db.ForeignKey('student.id')),
db.Column('teacher_id',db.Integer,db.ForeignKey('teacher.id'))
) db.create_all() @app.route('/')
def hello_world():
return 'Hello World!' @app.route('/01-addcourse')
def add_course():
course1 = Course('python基础')
course2 = Course('python高级')
course3 = Course('数据基础')
db.session.add(course1)
db.session.add(course2)
db.session.add(course3)
return '' @app.route('/02-register')
def register_teacher():
teacher = Teacher()
teacher.tname='吕老师'
teacher.tage = 28
course = Course.query.filter_by(id=3).first()
# teacher.course = course #通过关联属性course对象赋值
teacher.course_id = 1
db.session.add(teacher)
return '' @app.route('/03-query-teacher')
def query_teacher():
# 通过 course 查找对应的所有的老师们
# 查找course_id 为1的course对象
# course = Course.query.filter_by(id=1).first()
# print(course.cname)
# for tea in course.teachers.all():
# print(tea.tname) #通过teacher 查找对应的course
teacher = Teacher.query.filter_by(id=1).first()
print('老师姓名',teacher.tname)
course = teacher.course
print(course.cname) pass @app.route('/04-regTeacher',methods=['GET','POST'])
def reg_Teacher():
if request.method=='GET':
a = Course.query.all()
return render_template('regTeacher.html',a=a) elif request.method=='POST':
name = request.form['name']
age = request.form['age']
select = request.form['select1'] db.session.add(Teacher(name,age,select))
return '' @app.route('/05-showdata')
def showdata_05():
a = Teacher.query.all()
return render_template('showtea.html',a=a) @app.route('/06-regwife')
def regwife():
# wife = Wife('王dd夫人',18)
# wife.teacher_id=1
# db.session.add(wife) wife=Wife('老夫人',15)
teacher = Teacher.query.filter_by(tname='刘杰').first()
wife.teacher = teacher
db.session.add(wife)
return 'OK' @app.route('/07-querywife')
def querywife():
#通过teacher 找wife
# teacher = Teacher.query.filter_by(id=1).first()
# wife = teacher.wife # 通过wife找 teacher
wife = Wife.query.filter_by(id=2).first()
teacher = wife.teacher
return '%s--%s'%(teacher.tname,wife.wname) @app.route('/07-get')
def get_07():
a= Teacher.query.filter_by(id =4).first()
b = a.student
c = a.wife
print(b,c) return render_template('07-get.html',a=b) @app.route('/08')
def add_student_course():
# 获取id为1 的学员的信息
student =Student.query.filter_by(id=1).first()
# 获取 id为1 的课程信息
course = Course.query.filter_by(id=1).first()
# 将student 与 course 关联到一起
student.courses.append(course) db.session.add(student) for i in student.courses:
print(i)
return '' @app.route('/09')
def getM2M():#这里是多对多存储关系
courses = Course.query.filter_by(id=1).first()
students = courses.students.all()
print(students)
return '' @app.route('/10',methods=['GET','POST'])
def register_student():
if request.method=="GET":
s = Student.query.all()
t = Teacher.query.all()
return render_template('register_student.html',s=s,t=t)
elif request.method=='POST':
studen = request.form['select1']
teacher = request.form.getlist('select2')
print(teacher)
s = Student.query.filter_by(id=int(studen)).first()
t = Teacher.query.filter(Teacher.id.in_(teacher)).all()
for i in t :
s.teachers.append(i)
db.session.add(s) return 'OK' @app.route('/011')
def show_011():
s = Student.query.all()
return render_template('show_11.html',s=s) if __name__ == '__main__':
app.run(debug=True)

(内包含一对一,一对多,多对多的ORM实现)

2 cookies / cookie
1 什么是cookies
cookie 是一种数据的存储手段
将一段文本保存在客户端(浏览器)的一种手段,并可以长时间保存
2 cookies的使用场合
1 记住密码
2 记住搜索的关键词
3 Flask 中使用 cookies
1 使用响应对象,将数据保存进cookies(客户端)
1 resp = make_response('字符串'|rende_template())
2 resp = redirect('地址')
cookies的语法
响应对象.set_cookies(key,value,max_age)
key:保存的cookie的名称
value:保存的cookie的值
max_age:保存的时间,取值为数字,默认以s 为单位 2 获取 cookie的值
每次向服务器请求时,都会把cookie中的数据封装到request中并带到服务器上
在flask中通过request.cookies 获取所有的cookies值
3 删除cookie的值
响应对象. delete_cookie('key')
3 session - 会话
1 什么是session
session是保存在服务器上,为每个浏览器所开辟的一段空间
2 session 在Flask 中的实现
1 配置 SECRET_KEY
app.config['SECRET_KEY'] = ''
2 使用session
from flask import session
1 向session中保存数据
session['key'] = value
2 从session中取值
value = session['key']
value = session.get('key','')
3 从session中删除数据
del session['key']

flask 中的ORM ( 二 )的更多相关文章

  1. Flask中的ORM使用

    前言 ORM拓展 安装 数据库设置 使用 关系 单表操作 建表 应用表结构 CRUD 添加查找操作 更新操作 删除操作 一对多 多对多 总结 前言 最近几天接触了一下Flask,在惊叹于其简洁性的同时 ...

  2. flask 中的ORM

    1 响应(response) 1 什么是响应 响应就是由服务器端带给客户端的内容,对应着请求,响应可以是普通的字符串,模板 或重定向 return '普通字符串' return render_temp ...

  3. Flask 中的 SQLAlchemy 使用教程

    Flask 是一个 python web micro framework.所谓微框架,主要是 flask 简洁与轻巧,自定义程度高.相比 django 更加轻量级. 之前一直折腾 django,得益于 ...

  4. flask框架----整合Flask中的目录结构

    一.SQLAlchemy-Utils 由于sqlalchemy中没有提供choice方法,所以借助SQLAlchemy-Utils组件提供的choice方法 import datetime from ...

  5. Python框架学习之Flask中的数据库操作

    数据库操作在web开发中扮演着一个很重要的角色,网站中很多重要的信息都需要保存到数据库中.如用户名.密码等等其他信息.Django框架是一个基于MVT思想的框架,也就是说他本身就已经封装了Model类 ...

  6. 整合Flask中的目录结构

    一.SQLAlchemy-Utils 由于sqlalchemy中没有提供choice方法,所以借助SQLAlchemy-Utils组件提供的choice方法 import datetime from ...

  7. Flask学习【第11篇】:整合Flask中的一些知识点

    SQLAlchemy-Utils 由于sqlalchemy中没有提供choice方法,所以借助SQLAlchemy-Utils组件提供的choice方法 import datetime from sq ...

  8. Flask系列(十一)整合Flask中的目录结构(sqlalchemy-utils)

    一.SQLAlchemy-Utils 由于sqlalchemy中没有提供choice方法,所以借助SQLAlchemy-Utils组件提供的choice方法 import datetime from ...

  9. Flask中的的SQLAlchemy2

    昨天更新了博客不知对各位职场的大佬有没有帮助,如果没有看到的请用小手狠狠地戳这里 Flask中的的SQLAlchemy 今天呢,我们来说一下多对多表的关系,知道不?开始之前我先说一个事,昨晚更新了博客 ...

随机推荐

  1. 123457123457#0#-----com.yuming.YiZhiFanPai01--前拼后广--益智早教游戏记忆翻牌cym

    com.yuming.YiZhiFanPai01--前拼后广--益智早教游戏记忆翻牌cym

  2. 域账号修改后,导致vs中的git连接失败

    域账号修改后,导致vs中的git连接失败, fatal: Authentication failed for https://blog.csdn.net/qq_34665539/article/det ...

  3. rsync参数说明

    参数说明: log file = /var/log/rsyncd.log   #日志文件位置,启动rsync后自动产生这个文件,无需提前创建 pidfile = /var/run/rsyncd.pid ...

  4. 域名购买、SSL证书申请使用和本地服务映射外网

    万网购买域名 1.在如下网址购买,价格不是很贵,几块钱一年的都有:https://wanwang.aliyun.com/domain/?spm=5176.100251.111252.24.4ddd4f ...

  5. 【OpenGL学习】 四种绘制直线的算法

    我是用MFC框架进行测试的,由于本人也没有专门系统学习MFC框架,代码若有不足之处,请指出. 一,先来一个最简单的DDA算法 DDA算法全称为数值微分法,基于微分方程来绘制直线. ①推导微分方程如下: ...

  6. react如何在网页上编辑并运行代码?

    最近想做个能在网站,能在网页上运行代码,并且保存这个组件,看了一下element-react的组件和官方的实例,发现都是可以编辑运行的,因为之前没有这方面的经验,所以看下各位大佬能不能给点意见

  7. 谈谈NPM和Webpack的关系

    为什么有NPM: 当包引入数量很多时管理就成为了一个问题,这个就是npm为开发者行了方便之处,npm已经为你做好了依赖和版本的控制,也就是说使用npm可以让你从繁杂的依赖安装和版本冲突中解脱出来,进而 ...

  8. 4、1 IK分词器

    我们在浏览器地址栏输入 http://127.0.0.1:9200/_analyze?analyzer=chinese&pretty=true&text=我是程序员 默认的中文分词是将 ...

  9. airflow删除dag不在页面显示

    当我们需要把dag删除的时候,遇到了删除了相应的dag文件,但页面还是显示 这个时候需要重启airflow 的webserver  ps -ef|egrep  rm -rf /home/airflow ...

  10. Selenium绕过登录的实现

    1.使用命令行启动Chrome:Mac:/Applications/Google\ Chrome.app/Contents/MacOS/Google\ Chrome -remote-debugging ...