笔记一:
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 数据库一节笔记的更多相关文章

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

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

  2. mySQl数据库的学习笔记

    mySQl数据库的学习笔记... ------------------ Dos命令--先在记事本中写.然后再粘贴到Dos中去 -------------------------------- mySQ ...

  3. Mysql数据库基础学习笔记

    Mysql数据库基础学习笔记 1.mysql查看当前登录的账户名以及数据库 一.单表查询 1.创建数据库yuzly,创建表fruits 创建表 ) ) ,) NOT NULL,PRIMARY KEY( ...

  4. 天兔(Lepus)数据库监控系统安装笔记

    天兔(Lepus)数据库监控系统安装笔记 一.部署:本次操作系统:centos6.9 IP:192.168.153.145Lepus_v3.8_beta MySQL-python-1.2.5xampp ...

  5. 数据库MySQL学习笔记高级篇

    数据库MySQL学习笔记高级篇 写在前面 学习链接:数据库 MySQL 视频教程全集 1. mysql的架构介绍 mysql简介 概述 高级Mysql 完整的mysql优化需要很深的功底,大公司甚至有 ...

  6. Oracle数据库备份还原笔记

    Oracle数据库备份还原笔记 通过查阅资料知道Oracle备份还原的方式有三种.分别的是导出/导入.热备份和冷备份.导出/导入是一种逻辑备份.而热备份和冷备份是物理备份.[参考资料(https:// ...

  7. Flask RESTful API搭建笔记

    之前半年时间,来到项目的时候,已经有一些东西,大致就是IIS+MYSQL+PHP. 所以接着做,修修补补,Android/iOS与服务器数据库交换用PHP, Web那边则是JS+PHP,也没有前后端之 ...

  8. 测试Flask应用_学习笔记

    源代码尽在我的github上面:https://github.com/521xueweihan 欢迎大家交流学习 """ setUp() 方法中会创建一个新的测试客户端并 ...

  9. 细说flask数据库迁移

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

随机推荐

  1. MySQL数据库初识、下载使用(针对库、表、记录的增删改查)

    今日内容概要 数据演变史 数据库软件的本质 MySQL简介 下载与安装 基本配置 基本SQL语句 内容详细 1.数据演变史 # 1.单独的文本文件 没有固定的存放位置和格式 文件名:user.txt ...

  2. Solution -「CF 757F」Team Rocket Rises Again

    \(\mathcal{Description}\)   link.   给定 \(n\) 个点 \(m\) 条边的无向图和一个源点 \(s\).要求删除一个不同与 \(s\) 的结点 \(u\),使得 ...

  3. Solution -「六省联考 2017」「洛谷 P3750」分手是祝愿

    \(\mathcal{Description}\)   Link.   有 \(n\) 盏编号为 \(1\sim n\),已知初始状态的灯,每次操作选取 \(x\in[1,n]\),使得所有编号为 \ ...

  4. IDEA自带Http Client替代Postman校验接口

    对比Postman的优势 对于数据格式变动可以更为敏锐的观察到.生成的接口请求文件可以同步到代码库,支持多人使用. 使用说明 创建请求文件 使用IDEA,在项目的Scratches下创建Http Re ...

  5. c++动态内存管理与智能指针

    目录 一.介绍 二.shared_ptr类 make_shared函数 shared_ptr的拷贝和引用 shared_ptr自动销毁所管理的对象- -shared_ptr还会自动释放相关联对象的内存 ...

  6. Msftables之Linux NFS共享目录配置漏洞

    实验目的 1.了解Metasploitables靶机系统漏洞: 2.学习使用Metasploit. 实验原理 msftables之利用Linux NFS共享目录配置漏洞渗透. 实验内容 msftabl ...

  7. 企业bi解决方案,商业智能BI作用

    ​随着越来越多的公司将商业智能BI引入到日常运营和商业决策中,BI的热点逐渐起来了.商业智能系统兴起,那BI对企业有什么好处呢? 简单的说,就是可以帮助企业管理者直观清晰的看到自己想要关注的数据,帮助 ...

  8. 国产BI报表工具中低调的优秀“模范生”——思迈特软件Smartbi

    首先简单来介绍一下这位低调且优秀的模范生--思迈特软件Smartbi.思迈特Smartbi是企业级商业智能BI和大数据分析品牌,满足用户在企业级报表.数据可视化分析.自助分析平台.数据挖掘建模.AI智 ...

  9. 【vs2019 】调试技巧

    在这篇文章中,我们假定读者了解VS基本的调试知识,如: F5 开始使用调试器运行程序 F9 在当前行设置断点 F10 运行到下一个断点处 F5 从被调试的已停止程序恢复执行 F11 步进到函数内(如果 ...

  10. 相等性 比较【ReferenceEquals、静态Equals、==(ceq)、实例eEquals】

    感觉 最近学习学疯了,突然对以前熟悉的东西感到陌生.然后又回头重新挖掘一下 什么是相等性呢?以前一直用== 默认是值相等,从未去考虑,是地址相等还值相等.今天就详细的研究一下. .net 平台提供了4 ...