flask 数据库一节笔记
笔记一:
os.path的用法:
1. os.path.dirname(__file__) 返回当前脚本的执行路径,__file__为固定参数
2. os.path.abspath(file) 返回文件在当前环境中的绝对路径
3. os.path.join(basedir, file) 将file的路径设置为basedir所在的路径
笔记二:
Flask_SQLAlchemy数据库URL:
MySQL mysql://username:password@hostname/database
SQLite(Unix) sqlite:////absolute/path/to/database
SQLite(Windows) sqlite:///c:/absolute/path/to/database
笔记三:
常用的SQLAlchemy列类型如下:
Integer int 普通整数
Float float 浮点型
String str 变长字符串
Text str 做优化的变长字符串
Boolean bool 布尔值
Date datetime.date 日期
Time datatime.time 时间
Interval datetime.timedelta 时间间隔
SQLAlchemy列配置选项:
primary_key 如果为True,这列就是主键
unique 如果为True,这列不允许出现重复值
index 如果为True,这列创建索引,提升查询效率
nullable 如果为True,这列允许出现空值
dafault 为这列定义默认值
笔记四:
__repr__方法用于显示值,相似方法还有__str__,但前者更偏向开发人员(准确性),后者更偏向用户
笔记五:
imp是标准库模块,可以对模块进行创建、载入等操作,可以用exec执行模块文件
笔记六:
可使用db.relationship()把数据库的不同行联系起来,建立一对多的关系,db.relationship()的第一个
参数表明关系的另一端是哪个模型,其他可选参数如下:
backref 在关系的另一个模型中添加反向引用
primaryjoin 明确两个模型之间使用的联结条件
lazy 指定如何加载相关记录,可选值有select(首次访问时加载)、immediate(源对象加载后加载)、
joined(加载记录,但使用联结)、subquery(立即加载,但使用子查询),noload(永不加载)、
dynamic(不加载记录,但提供加载记录的查询)
uselist 如果设为False,不适用列表而使用标量
order_by 指定关系中记录的排序方式
secondary 指定多对多关系中关系表的名字
secondaryjoin 指定多对多关系中的二级联结条件
用SQLAlchemy管理数据库的步骤:
1. 配置数据库:
①设置数据库SQLALCHEMY_DATABASE_URI (必须)
②设置数据库迁移文件路径SQLALCHEMY_MIGRATE_REPO(自动更新数据库变动)
2. 初始化数据库(用SQLAlchemy()创建一个db对象)
3. 创建数据库模型
用类来创建数据库模型,用__repr__方法打印类的对象,便于调试
4. 创建数据库
用SQLAlchemy_migrate创建支持升级的数据库
从migrate.versioning导入api
api.create()
api.version_control()
5. 创建迁移脚本
...
使用migrate.versioning模块api方法的upgrate()升级数据库,downgrate()回退数据库
6. 建立数据库中表的对应关系
用db.relationship()、外键等建立关系
7. 用session会话对数据库进行操作,最后必须使用db.session.commit()才生效
db.session.add() 更改
db.session.delete() 删除行
query.all() 查询,可使用过滤器filter_by进行更精确查询
flask 数据库一节笔记的更多相关文章
- 实验3、Flask数据库操作-如何使用Flask与数据库
1. 实验内容 数据库的使用对于可交互的Web应用程序是极其重要的,本节我们主要学习如何与各种主要数据库进行连接和使用,以及ORM的使用 2. 实验要点 掌握Flask对于各种主要数据库的连接方法 掌 ...
- mySQl数据库的学习笔记
mySQl数据库的学习笔记... ------------------ Dos命令--先在记事本中写.然后再粘贴到Dos中去 -------------------------------- mySQ ...
- Mysql数据库基础学习笔记
Mysql数据库基础学习笔记 1.mysql查看当前登录的账户名以及数据库 一.单表查询 1.创建数据库yuzly,创建表fruits 创建表 ) ) ,) NOT NULL,PRIMARY KEY( ...
- 天兔(Lepus)数据库监控系统安装笔记
天兔(Lepus)数据库监控系统安装笔记 一.部署:本次操作系统:centos6.9 IP:192.168.153.145Lepus_v3.8_beta MySQL-python-1.2.5xampp ...
- 数据库MySQL学习笔记高级篇
数据库MySQL学习笔记高级篇 写在前面 学习链接:数据库 MySQL 视频教程全集 1. mysql的架构介绍 mysql简介 概述 高级Mysql 完整的mysql优化需要很深的功底,大公司甚至有 ...
- Oracle数据库备份还原笔记
Oracle数据库备份还原笔记 通过查阅资料知道Oracle备份还原的方式有三种.分别的是导出/导入.热备份和冷备份.导出/导入是一种逻辑备份.而热备份和冷备份是物理备份.[参考资料(https:// ...
- Flask RESTful API搭建笔记
之前半年时间,来到项目的时候,已经有一些东西,大致就是IIS+MYSQL+PHP. 所以接着做,修修补补,Android/iOS与服务器数据库交换用PHP, Web那边则是JS+PHP,也没有前后端之 ...
- 测试Flask应用_学习笔记
源代码尽在我的github上面:https://github.com/521xueweihan 欢迎大家交流学习 """ setUp() 方法中会创建一个新的测试客户端并 ...
- 细说flask数据库迁移
什么情况下要用数据库迁移? 在开发过程中,需要修改数据库模型,而且还要在修改之后更新数据库.最直接的方式就是删除旧表,但这样会丢失数据. 更好的解决办法是使用数据库迁移框架,它可以追踪数据库模式的变化 ...
随机推荐
- 3、架构--cp、scp、rsync、实时监控与同步
笔记 1.晨考 1.VPN的搭建步骤 2.vpn中的iptables是什么作用? 网络转发 2.昨日问题 1.yum源问题 2.VPN链接正常,但是没办法通过172 3.VPN链接时,出现了DNS错误 ...
- .NET 云原生架构师训练营(权限系统 代码实现 WebApplication)--学习笔记
目录 开发任务 代码实现 开发任务 DotNetNB.Security.Core:定义 core,models,Istore:实现 default memory store DotNetNB.WebA ...
- INTERSPEECH 2015 | Scalable Distributed DNN Training Using Commodity GPU Cloud Computing
一般来说,全连接层的前向和后向传递所需的计算量与权重的数量成正比.此外,数据并行训练中所需的带宽与可训练权重的数量成比例.因此,随着每个节点计算速度的提高,所需的网络带宽也随之增加.这篇文章主要是根据 ...
- 详细介绍Windows下也能够使用osw性能升级历史
1.Windows系统历史性能分析困难背景 在Linux/Unix上.要追朔历史性能,一般採用部署nmon进行性能监控採集与存储的方式实现.可是却没有在Windows上的版本号. Windows系统假 ...
- 神奇!这款 Vue 后台框架居然不用手动配置路由
前言 做 Vue 开发脱离不了路由,尤其是中大型项目,页面多且杂,在配置路由的时候总是会变得逐渐暴躁,因为费时,并且又没有什么太多技术含量,总觉得是在浪费时间. 另外如果接手了别人的项目,当业务有变更 ...
- 商业智能BI与用户行为分析的联系
什么是BI? BI(Business Intelligence)即商业智能,它是一套完整的解决方案,用来将企业中现有的数据进行有效的整合,分析利用企业已有的各种商用数据来了解企业的经营状况和外部环境 ...
- 【C# Parallel】ParallelOptions
ParallelOptions 构造函数 此构造函数用默认值初始化实例. MaxDegreeOfParallelism 初始化为-1,表示没有对应采用的并行度进行上限设置. CancellationT ...
- 【C# IO 操作 】开篇 IO命名空间的解析
图片模板下载 System.IO命名空间类分为:文件.驱动 .目录.路径.流.比特率流的操作 驱动类:比较简单,所以就不区分静态和实例操作类,所有的操作合并在DriverInfo类中 路径类:比较简单 ...
- 【C# 练习】通过ZoomGame这个案例加强对 反射 插件 特性的认识
游戏情景设定: 有一个游戏机,里面出现几种动物让儿童选择.选择完动物后,在输入数值让动物叫几次. 动物类型以插件的形势存在,可以外包给其他人开发,并提供了开发接口AnimalTool.SDK.dll. ...
- vue+element ui后台遇到的坑
今天在用elementui做后台系统,遇到第一个坑:分页显示的是英文 按照官网组件复制下来的代码: <el-row :gutter="0" style="margi ...