3.数据库模型设计

3.1构建蓝图项目目录

1.前后台项目目录分析

 

2.蓝图构建项目目录

蓝图:一个应用中或跨域应用制作组件和支持通用模式。

蓝图的作用:将不同的功能模块化

构建大型应用

优化项目结构

增强可读性,易于维护

  1. 定义蓝图(app/admin/__init__.py)

From flask import Blueprint

Admin = Blueprint(“admin”,__name__)

Import views

  1. 注册蓝图(app/__init__.py)

From admin import admin as admin_blueprint

app.register_blueprint(admin_blueprint,url_prefix=”/admin”)

  1. 调用蓝图(app/admin/views.py)

from .import admin

@admin.route(“/”)

3.会员及会员登录日志数据模型设计

  1. 安装数据库连接依赖包

pip install flask-sqlalchemy

  1. 定义数据库连接

from flask import Flask

from flask_sqlalchemy import SQLAlchemy

app = Flask(__name__)

app.config["SQLALCHEMY_DATABASE_URI"] = "mysql://root:root@localhost:3306"  #换成自己的数据库名字

app.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = True

db = SQLAlchemy(app)

  1. 定义会员数据模型

Id:编号、name:账号、pwd:密码、email:邮箱、phone:手机号、info:简介、face:头像

Addtime:注册时间、uuid:唯一标识符、comments:评论外键关联、userlogs:会员登录日志外键关联、moviecols:电影收藏外键关联

class User(db.Model):

__tablename__ = "user"

id = db.Column(db.Integer, primary_key=True) #编号

name = db.Column(db.String(100),unique=True) #昵称

pwd = db.Column(db.String(100))  #密码

email = db.Column(db.String(100),unique=True)  #邮箱

phone = db.Column(db.String(11),unique=True)  #手机号码

info = db.Column(db.Text)   #个性简介

face = db.Column(db.String(255),unique=True)  #头像

addtime = db.Column(db.DateTime,index=True,default=datetime.utcnow)

uuid = db.Column(db.String(255),unique=True)  #唯一标识符

userlogs = db.relationship('Userlog',backref = 'user') #会员日志外键关系

会员登录日志

Id:编号、

user_id:所属会员编号、

ip:最近登录ip地址、

addtime:最近登录时间

定义标签

Id:编号、Name:标题、Movies:电影外键关联、Addtime:添加时间

电影

Id:编号、title:电影标题、url:电影地址、info:电影简介、logo:电影封面、star:星级、

playnum:电影播放量、commentnum:电影评论量、tag_id:所属标签、area:地区、

release_time:发布时间、length:电影长度、addtime:添加时间、comments:电影评论外键关联、moviecols:电影收藏外键关联、

上映预告

Id:编号、Name:上映预告标题、Logo:上映预告封面、Addtime:添加时间

评论

Id:编号、Content:评论内容、Movie_id:所属电影、User_id:所属用户、Addtime:最近登录时间

收藏电影:

Id:编号、Movie_id:所属电影、User_id:所属用户、Addtime:最近登录时间

 权限:

Id:编号、Name:编号、URL :地址、addtime:创建时间

角色:

Id:编号、Name:名称、Auths:权限列表、Addtime:创建时间

管理员:

Id:编号、name:管理员名称、pwd:管理员密码、is_super:是否超级管理员、role_id:角色编号、addtime:创建时间、adminlogs:管理员登录日志外键关联、oplogs:操作日志外键关联。

管理员登录日志:

Id:编号、admin_id:所属管理员编号、ip:最近登录地址、addtime:添加时间

操作日志:

Id:编号、admin_id:所属管理员编号、ip:啊哦做地址、reason:操作原因、addtime:添加时间

models.py

#coding:utf-8
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from _datetime import datetime
import pymysql
#定义数据库连接
app = Flask(__name__) #创建实例化app对象
app.config["SQLALCHEMY_DATABASE_URI"] = "mysql+pymysql://root:root@localhost:3306/movie"
app.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = True #配置,如果设置True,将会追踪对象修改并且发送信号
db = SQLAlchemy(app) #定义db,传入app对象 #定义会员数据模型
class User(db.Model):
__tablename__ = "user" #存入表名称
#column字段 unique唯一
id = db.Column(db.Integer, primary_key=True) #编号
name = db.Column(db.String(100),unique=True) #昵称
pwd = db.Column(db.String(100)) #密码
email = db.Column(db.String(100),unique=True) #邮箱
phone = db.Column(db.String(11),unique=True) #手机号码
info = db.Column(db.Text) #个性简介
face = db.Column(db.String(255),unique=True) #头像
addtime = db.Column(db.DateTime,index=True,default=datetime.utcnow)
uuid = db.Column(db.String(255),unique=True) #唯一标识符
userlogs = db.relationship('Userlog',backref='user') #会员日志外键关系
comments = db.relationship('Comment',backref='user') #评论外键关系
moviecols = db.relationship('Moviecol',backref='user') #收藏外键关系 #定义一个方法,返回的类型
def __repr__(self):
return "<User %r>" % self.name
#会员登录日志
class Userlog(db.Model):
__tablename__ = "userlog" #定义表名
id = db.Column(db.Integer,primary_key=True) #编号
#定义外键 db.ForeignKey
user_id = db.Column(db.Integer,db.ForeignKey('user.id')) #所属会员
ip = db.Column(db.String(100)) #登录IP
addtime = db.Column(db.DateTime,index=True,default=datetime.utcnow) #登录时间 ,默认时间 def __repr__(self):
return "<Userlog %r>" % self.id #定义标签
class Tag(db.Model):
__tablename__ = "tag" #定义表名称
id = db.Column(db.Integer,primary_key=True) #编号
name = db.Column(db.String(100),unique=True) #名称
addtime = db.Column(db.DateTime,index=True,default=datetime.utcnow) #添加时间
movies = db.relationship("Movie",backref='tag') #电影外键关系关联
#返回类型
def __repr__(self):
return "<Tag %r>" %self.name #电影
class Movie(db.Model):
__tablename__ = "movie" #定义表名称
id = db.Column(db.Integer,primary_key=True) #编号
title = db.Column(db.String(255),unique=True) #标题
url = db.Column(db.String(255),unique=True) #地址
info = db.Column(db.Text) #简介
logo = db.Column(db.String(255),unique=True) #封面
star = db.Column(db.SmallInteger) #星级 小整形
playnum = db.Column(db.BigInteger) #播放量
commentnum = db.Column(db.BigInteger) #评论量
tag_id = db.Column(db.Integer,db.ForeignKey('tag.id')) #所属标签
area = db.Column(db.String(255)) #上映地区
release_time = db.Column(db.Date) #上映时间
length = db.Column(db.String(100)) #播放时间
addtime = db.Column(db.DateTime,index=True, default=datetime.utcnow) #添加时间
comments = db.relationship("Comment",backref='movie') #评论外键关系关联
moviecols = db.relationship("Moviecol",backref='movie') #收藏外键关系关联 def __repr__(self):
return "<Movie %r>" %self.title
#上映预告
class Preview(db.Model):
__tablename__ = "preview" #定义表名
id = db.Column(db.Integer,primary_key=True) #编号
title = db.Column(db.String(255),unique=True) #标题
logo = db.Column(db.String(255),unique=True) #封面
addtime = db.Column(db.DateTime,index=True,default=datetime.utcnow) #添加时间
def __repr__(self):
return "<Preview %r>" %self.title #评论
class Comment(db.Model):
__tablename__ = "comment" #定义表名
id = db.Column(db.Integer,primary_key=True) #编号
content = db.Column(db.Text) #内容
movie_id = db.Column(db.Integer,db.ForeignKey('movie.id')) #所属电影
user_id = db.Column(db.Integer,db.ForeignKey('user.id')) #所属用户
addtime = db.Column(db.DateTime,index=True,default=datetime.utcnow) #添加时间
def __repr__(self):
return "<Comment %r>" %self.id #电影收藏
class Moviecol(db.Model):
__tablename__ = "moviecol" #定义表名
id = db.Column(db.Integer,primary_key=True) #编号
movie_id = db.Column(db.Integer,db.ForeignKey('movie.id')) #所属电影
user_id = db.Column(db.Integer,db.ForeignKey('user.id')) #所属用户
addtime = db.Column(db.DateTime,index=True,default=datetime.utcnow) #添加时间
def __repr__(self):
return "<Moviecol %r>" % self.id #权限
class Auth(db.Model):
__tablename__ = "auth" #定义表名
id = db.Column(db.Integer,primary_key=True) #编号
name = db.Column(db.String(100),unique=True) #名称
url = db.Column(db.String(255),unique=True) #地址
addtime = db.Column(db.DateTime,index=True,default=datetime.utcnow) #添加时间
def __repr__(self):
return "<Auth %r>" % self.name
#角色
class Role(db.Model):
__tablename__ = "role" #定义表名
id = db.Column(db.Integer,primary_key=True) #编号
name = db.Column(db.String(100),unique=True) #名称
auths = db.Column(db.String(600))
addtime = db.Column(db.DateTime,index=True,default=datetime.utcnow) #添加时间
def __repr__(self):
return "<Role %r>" % self.name #管理员
class Admin(db.Model):
__tablename__ = "admin" #存入表名称
id = db.Column(db.Integer, primary_key=True) #编号
name = db.Column(db.String(100),unique=True) #管理员账号
pwd = db.Column(db.String(100)) #管理员密码
is_super = db.Column(db.SmallInteger) #是否为超级管理员,0为超级管理员
role_id = db.Column(db.Integer,db.ForeignKey('role.id')) #所属角色
addtime = db.Column(db.DateTime,index=True,default=datetime.utcnow) #添加时间
adminlogs = db.relationship("Adminlog",backref='admin') #管理员登录日志外键关系关联
oplogs = db.relationship("Oplog",backref='admin') #管理员操作日志外键关系关联
def __repr__(self):
return "<Role %r>" % self.name #管理员登录日志
class Adminlog(db.Model):
__tablename__ = "adminlog" #定义表名
id = db.Column(db.Integer,primary_key=True) #编号
#定义外键 db.ForeignKey
admin_id = db.Column(db.Integer,db.ForeignKey('admin.id')) #所属管理员
ip = db.Column(db.String(100)) #登录IP
addtime = db.Column(db.DateTime,index=True,default=datetime.utcnow) #登录时间 ,默认时间
def __repr__(self):
return "<Adminlog %r>" % self.id #操作日志
class Oplog(db.Model):
__tablename__ = "oplog" #定义表名
id = db.Column(db.Integer,primary_key=True) #编号
#定义外键 db.ForeignKey
admin_id = db.Column(db.Integer,db.ForeignKey('admin.id')) #所属管理员
ip = db.Column(db.String(100)) #登录IP
reason = db.Column(db.String(600)) #操作原因
addtime = db.Column(db.DateTime,index=True,default=datetime.utcnow) #登录时间 ,默认时间
def __repr__(self):
return "<Oplog %r>" % self.id if __name__ == "__main__":
#db.create_all()
'''role = Role(
name="超级管理员",
auths=" "
)
db.session.add(role)
db.session.commit()'''
from werkzeug.security import generate_password_hash #导入一个生成密码的工具
admin = Admin(
name="flower",
pwd=generate_password_hash("123456"),
is_super=0,
role_id=1
)
#调用admin
db.session.add(admin)
db.session.commit()

  

flask-数据库模型设计2的更多相关文章

  1. 数据库模型设计PowerDesigner

    Power Designer 是Sybase公司的CASE工具集,使用它可以方便地对管理信息系统进行分析设计,他几乎包括了数据库模型设计的全过程.利用Power Designer可以制作数据流程图.概 ...

  2. One to One 的数据库模型设计与NHibernate配置

    在数据库模型设计中,最基本的实体关系有三种:一对一.一对多.多对多.关于一对多和多对多使用的情况较多,之前也有过一些讨论,现在来说明一下在数据库中一对一的模型设计. 首先,关系数据库中使用外键来表示一 ...

  3. ASP.NET MVC+EF框架+EasyUI实现权限管理系列(15)-用户登录详细错误和权限数据库模型设计

    原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(15)-用户登录详细错误和权限数据库模型设计     ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇)    ...

  4. 实验3、Flask数据库操作-如何使用Flask与数据库

    1. 实验内容 数据库的使用对于可交互的Web应用程序是极其重要的,本节我们主要学习如何与各种主要数据库进行连接和使用,以及ORM的使用 2. 实验要点 掌握Flask对于各种主要数据库的连接方法 掌 ...

  5. 细说flask数据库迁移

    什么情况下要用数据库迁移? 在开发过程中,需要修改数据库模型,而且还要在修改之后更新数据库.最直接的方式就是删除旧表,但这样会丢失数据. 更好的解决办法是使用数据库迁移框架,它可以追踪数据库模式的变化 ...

  6. flask数据库迁移理解及命令

    前言: 使用数据库迁移,可以直接建表,而不用我们自己写sql语句用来建表.就是将关系型数据库的一张张表转化成了Python的一个个类. 在开发中经常会遇到需要修改原来的数据库模型,修改之后更新数据库, ...

  7. 03 flask数据库操作、flask-session、蓝图

    ORM ORM 全拼Object-Relation Mapping,中文意为 对象-关系映射.主要实现模型对象到关系数据库数据的映射. 1.优点 : 只需要面向对象编程, 不需要面向数据库编写代码. ...

  8. flask~数据库

    flask与数据库的连接基于flaks_sqlaichemy 扩展 首先要连接数据库的时候必须得先下载 pip install flask-sqlalchemy 这个扩展 flask框架与数据库的连接 ...

  9. flask数据库操作

    Python 数据库框架 大多数的数据库引擎都有对应的 Python 包,包括开源包和商业包.Flask 并不限制你使用何种类型的数据库包,因此可以根据自己的喜好选择使用 MySQL.Postgres ...

  10. EF基础知识小记四(数据库=>模型设计器)

    EF基础知识小记三(设计器=>数据库)介绍了如何创建一个空设计器模型,并如何将模型同步到数据库的表中,本文则主要介绍如何将一个存在的数据库同步到模型设计器中.为了能快速的模拟这个过程,给出一下建 ...

随机推荐

  1. 【ASP.NET】System.Web.Routing - RouteCollection Class

    Provides a collection of routes for ASP.NET routing. The RouteCollection class provides methods that ...

  2. Kubernetes工作流之Pods二

    Init Containers This feature has exited beta in 1.6. Init Containers can be specified in the PodSpec ...

  3. 转载:mysql存储过程讲解

    记录MYSQL存储过程中的关键语法: DELIMITER // 声明语句结束符,用于区分; CEATE PROCEDURE demo_in_parameter(IN p_in int) 声明存储过程 ...

  4. CSS基本内容

    CSS样式表的三种引入方式: 1.外部样式表——即将CSS样式写在单独的一个.css文件中: <link rel="stylesheet" type="text/c ...

  5. springmvc后台接前端的参数,数组,集合,复杂对象等

    springmvc后台接前端的参数,数组,集合,复杂对象等 参考地址:https://blog.csdn.net/feicongcong/article/details/54705933  常用的几种 ...

  6. Python pycharm 常用快捷键

    快捷键 1.编辑(Editing) Ctrl + Space 基本的代码完成(类.方法.属性) Ctrl + Alt + Space 快速导入任意类 Ctrl + Shift + Enter 语句完成 ...

  7. mesh合并

    [风宇冲]Unity3D性能优化:DrawCall优化 (2013-03-05 15:39:27) 转载▼ 标签: it unity unity3d unity3d教程 分类: Unity3d之优化 ...

  8. ppython的移位操作

    因为要将js的一个签名算法移植到python上,遇到一些麻烦. int无限宽度,不会溢出 算法中需要用到了32位int的溢出来参与运算,但是python的int是不会溢出的,达到界限后会自己转为lon ...

  9. VS2010:“error C2712: 无法在要求对象展开的函数中使用 __try”

    ZC:这个错误是在使用 "__try{...} __except(EXCEPTION_EXECUTE_HANDLER){}"时 遇到的 http://blog.csdn.net/c ...

  10. 【Linux】人脸识别的封装

    写了一个linux下的Face Recognition的封装,当作是练习.语言: C++的封装,结合opencv,使用方便.下载源码:https://github.com/zacario-li/Fac ...