一、数据库框架 Flask-SQLAlchemy

  (1)安装: pip install flask-sqlalchemy

  (2)Flask-SQLAlchemy数据库URL

数据库引擎 URL
MySQL mysql://username:password@hostname/database
Postgres postgresql://username:password@hostname/database
SQLite(Unix) sqlite:////abslute/path/to/database
SQLite(Windows) sqlite:///c:/absolute/path/tp/database

二、配置数据库

from flask.ext.sqlalchemy import SQLAlchemy
basedir = os.path.abspath(os.path.dirname(__file__)
app = Flask(__name__)
app.config['SQLACHEMY_DATABASE_URI'] = \'sqlite:///' + os.path.join(basedir,'data.sqlite')
app.config['SQLACHEMY_COMMIT_ON_TEARDOWN'] = True
db = SQLAlchemy(app)

三、定义模型

**roles表和user表定义模型Role和User

class Role(db.Model):
#数据库中使用的表名
__tablenaame__ = 'roles'
id = db.Column(db.Integer, primary_key =True)
name = db.column(db.String(64),unique = True)
def __repr__(self):
return <Role %r>' % self.name class User(db.Model):
__tablenaame__ = 'users'
id = db.Column(db.Integer, primary_key =True)
username = db.column(db.String(64),unique = True,index = True)
def __repr__(self):
return <User %r>' % self.username

  (2)最常使用的SQLAlchemy列选项

选项名 说明
primary_key 主键,经常是ID
unique 不允许出现重复的值
index 创建索引,提升查询效率
nullable 允许空值
default 定义默认值

四、关系

  (1)一对多关系

class Role(db.Model):
#数据库中使用的表名
'''
__tablenaame__ = 'roles'
id = db.Column(db.Integer, primary_key =True)
name = db.column(db.String(64),unique = True)
'''
users = db.relationship('User',backref = 'role')
'''
def __repr__(self):
return <Role %r>' % self.name
'''
class User(db.Model):
'''
__tablenaame__ = 'users'
id = db.Column(db.Integer, primary_key =True)
username = db.column(db.String(64),unique = True,index = True)
'''
role_id = db.Column(db.Integer,db.ForeignKey('role.id'))
'''
def __repr__(self):
return <User %r>' % self.username
'''

  (2)常用的关系项

选项 说明
backref 在关系的另一个模型中添加反向引用
primaryjoin 明确两个模型中间的连接条件
lazy 指定加载相关记录
uselist 设置Fales,不使用列表
order_by 指定关系中记录的排序方式
secondary 指定多对多关系表的名字
secondaryjoin 无法自行决定时,指定多堆垛关系的耳机连接条件

**lazy可选值select(首次访问时需要加载),immediate(源对象加载后就加载),joined(加载记录,单使用连接),subquery(立即加载,单使用子查询),noload(永不加载)和dynamic(不加载记录,单提供加载记录查询)

**db.relationship(),把uselist设置为False,把“多”变成“一”

五、数据库操作

  (1)创建表

from hello import db
db.create_all()

**创建一个名字为data.sqlite

  (2)插入行

db.session.all_all([admin_role,mod_role,user_role,user_john,user_susan,user_david])
#提交数据
db.session.commit()

**数据回滚 db.session.rollback()

  (3)修改行

#把"Admin" 角色重命名为"Administrator"
admin_role.name = 'Administrator'
db.session.add(admin_role)
db.session.commit()

  (4)删除行

db.session.delete(mod_role)
db.session.commit()

  (5)查询行

 

  5.2常用的查询过滤器

过滤器 说明
filter 把过滤器添加到原查询上,返回一个新查询
filter_by 把等值过滤器添加到原查询上,返回一个新查询
limit 使用指定的值限制原查询返回的结果数量,返回一个查询
offset 偏移原查询返回的结果,返回一个新查询
order_by 根据指定条件对原查询结果进行排序,返回一个新查询
group_by 根据指定条件对原查询结果进行分组,返回一个新查询

  5.3常用查询执行函数

方法 说明
all 以列表形式返回查询的所有结果
first 返回查询的第一个结果,没有结果返回None
first_or_404 返回查询的第一个结果,没有结果,返回404错误
get 返回指定主键对应的行,没有结果返回None
get_or_404 返回指定主键对应的行,没有结果,返回404错误
count 返回查询的结果的数量
paginate 返回Paginate对象,它包含指定范围内容的结果

六、在视图函数中操作数据库

七、集成Python shell  ?

  为shell命令添加一个上下文

def make_shell_context():
return dict(app=app,db=db,User=User,Role=Role)
manager.add_command("shell",Shell(make_context=make_shell_context)

**make_shell_context函数注册了程序,数据库实例以及模型,因此这些对象能直接导入shell

八、数据库迁移(Flask-Migrate)

  (1)安装 :  pip install flask-migrate

  (2)配置Flask-Migrate

form flask.ext.migrate import Migrate,MigrateCommand
#...
migrate = Migrate(app,db)
manager.add_command('db',MigrateCommand)

  (2)迁移脚本

    upgrade()函数把迁移中的改动应用到数据库中

    downgrade()函数责将改动删除

    自动迁移脚本: python hello.py db migrate -m "initial migration"

九、更新数据库

  python hello.py db upgrade

Python——Flask框架——数据库的更多相关文章

  1. python flask框架 数据库的使用

    #coding:utf8 from flask import Flask from flask_sqlalchemy import SQLAlchemy app = Flask(__name__) # ...

  2. #3使用html+css+js制作网页 番外篇 使用python flask 框架 (II)

    #3使用html+css+js制作网页 番外篇 使用python flask 框架 II第二部 0. 本系列教程 1. 登录功能准备 a.python中操控mysql b. 安装数据库 c.安装mys ...

  3. Linux ubantu中安装虚拟/使用环境virtualenv以及python flask框架

    今天学习了python flask框架的安装过程以及使用案例,感觉网上讲的东西都没有从我们这种初学者的角度去考虑(哈哈),最后还是奉上心得: 1.安装virtualenv $ sudo apt-get ...

  4. python flask框架学习——开启debug模式

    学习自:知了课堂Python Flask框架——全栈开发 1.flask的几种debug模式的方法 # 1.app.run 传参debug=true app.run(debug=True) #2 设置 ...

  5. python flask框架学习(二)——第一个flask程序

    第一个flask程序 学习自:知了课堂Python Flask框架——全栈开发 1.用pycharm新建一个flask项目 2.运行程序 from flask import Flask # 创建一个F ...

  6. python flask框架学习(一)——准备工作和环境配置与安装

    Flask装备: 学习自:知了课堂Python Flask框架——全栈开发 1.Python版本:3.6 2.Pycharm软件: 3.安装虚拟环境: (1)安装virtualenv: pip ins ...

  7. #3使用html+css+js制作网页 番外篇 使用python flask 框架 (I)

    #3使用html+css+js制作网页 番外篇 使用python flask 框架(I 第一部) 0. 本系列教程 1. 准备 a.python b. flask c. flask 环境安装 d. f ...

  8. Python Flask框架路由简单实现

    Python Flask框架路由的简单实现 也许你听说过Flask框架.也许你也使用过,也使用的非常好.但是当你在浏览器上输入一串路由地址,跳转至你所写的页面,在Flask中是怎样实现的,你是否感到好 ...

  9. python Flask框架mysql数据库配置

    我是一个没有笔记习惯的低级程序员,但是我还是喜欢编程,从小学就开始跟着玩电脑,对抓鸡,ddos,跳板刷钻开始了自己的IT 旅程,之后学习了各种语言,但是可惜都不没有达到精通,都是略懂一二,现在想把Py ...

随机推荐

  1. pytorch visdom可视化工具学习—1—详细使用-2-plotting绘图

    3)plotting绘图 我们已经包装了几种常见的plot类型,以便轻松创建基本的可视化.这些可视化是由Plotly驱动的. Visdom支持下列API.由 Plotly 提供可视化支持. vis.s ...

  2. lintcode 515. Paint House

    Paint House 自己的写法: class Solution { public: /** * @param costs: n x 3 cost matrix * @return: An inte ...

  3. mybatis错误之org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)

    玩了MyBatis差不多有两年了,中间也玩过MyBatis-Plus,这个MyBatis-Plus其实与MyBatis的区别并不大.今天写博客业务代码的时候,犯一个初学者犯过的错误. 错误信息如下:o ...

  4. 初学Python——字符串相关操作

    基本字符串操作 Pyhton中字符串的格式化输出在前面已经总结了,接下来介绍一些常用的字符串操作 先定义一个字符变量,以下的操作都以此为例: name=" my name is china ...

  5. kali 源

    #阿里云 deb http://mirrors.aliyun.com/kali kali-rolling main non-free contrib deb-src http://mirrors.al ...

  6. ESP8266开发综合篇第一节(LUA)-下载和刷固件

    本节视频:  https://v.youku.com/v_show/id_XNDAwMTI2OTg2MA==.html?spm=a2h3j.8428770.3416059.1 一,整版测试 刷入测试固 ...

  7. .NET Core中复制源文件夹下的所有内容到新文件夹

    .NET Core中没有原生的复制文件夹方法,我们可以自己写个: 新建一个.NET Core控制台项目,示例代码如下: using System; using System.IO; namespace ...

  8. WindowsFormsHost下MouseWheel失效的解决办法

    原文:WindowsFormsHost下MouseWheel失效的解决办法 看了网上有些写的用钩子,但是,在Stack Overflow上找到一个简便的方式

  9. Java多线程学习(四)---控制线程

    控制线程 摘要: Java的线程支持提供了一些便捷的工具方法,通过这些便捷的工具方法可以很好地控制线程的执行 1. join线程控制,让一个线程等待另一个线程完成的方法 2. 后台线程,又称为守护线程 ...

  10. Java多线程学习(三)---线程的生命周期

    线程生命周期 摘要: 当线程被创建并启动以后,它既不是一启动就进入了执行状态,也不是一直处于执行状态.在线程的生命周期中,它要经过新建(New).就绪(Runnable).运行(Running).阻塞 ...