Flask架站基础篇(七)--SQLAlchemy(1)
时间:2022-07-24
本文章向大家介绍Flask架站基础篇(七)--SQLAlchemy(1),主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
零、什么是SQLAlchemy
SQLAlchemy是 Python 中常用的ORM框架
一、安装
在命令行中打开虚拟环境,在虚拟环境中输入如下命令:
pip install flask-sqlalchemy
二、设置连接字符串连接数据库
1.初始化sqlalchemy对象
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
app = Flask(__name__)
# 初始化sqlalchemy对象
db = SQLAlchemy(app)
@app.route('/')
def index():
return 'index'
if __name__ == '__main__':
app.run(debug=True)
2.设置连接字符串
DIALECT = 'mysql' # 所连接的数据库累心
DRIVER = 'mysqldb' # 数据库驱动名称
USERNAME = 'root' # 数据库用户名
PASSWORD = 'root' # 数据库密码
HOST = '127.0.0.1' # 数据库地址
PORT = '3306' # 数据库端口号
3.引入配置文件
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
# 引入config
import config
app = Flask(__name__)
# 设置配置
app.config.from_object(config)
# 初始化sqlalchemy对象
db = SQLAlchemy(app)
#验证是否连接正确
db.create_all()
@app.route('/')
def index():
return 'index'
if __name__ == '__main__':
app.run(debug=True)
三、模型与表映射
- 数据库模型必须集成db.Model
- 如果表名称没有指定,将使用类名称的小写形式
- 表属性名称必须以开头,以结尾
- 只要是映射到数据库的字段,必须=db.Column()
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
import config
app = Flask(__name__)
app.config.from_object(config)
db = SQLAlchemy(app)
# 数据库模型必须继承db.Model
class Article(db.Model):
# 定义表名,如果不指定表名,将使用类名称的小写形式,
# 表名属性必须以__开头__结尾
__tablename__ = 'article'
# 只要是映射到数据库的字段,必须=db.Column()
# 参数解释
# db.Integer:数据类型,此处为整型
# primary_key:是否是主键,此处是主键
# autoincrement=True:是否自增长,此处是自增长
id = db.Column(db.Integer, primary_key=True, autoincrement=True)
# db.String(100):最大长度为100的字符串类型
# nullable:是否可以为空
title = db.Column(db.String(100), nullable=False)
content = db.Column(db.Text, nullable=False)
# 映射表
db.create_all()
@app.route('/')
def hello_world():
return 'Hello World!'
if __name__ == '__main__':
app.run(debug=True)
- 创建 GitHub 仓库的步骤及方法
- React Native和原生app通信机制详解
- Python高效编程技巧
- 模块和处理程序之通过HttpModule和HttpHandler拦截入站HTTP请求执行指定托管代码模块
- iOS如何实现多个环境一次打包
- iOS 轻量级存储
- 深入理解React Native页面构建渲染原理
- React native城市列表组件
- iframe 解析
- React Native之StyleSheet样式表
- jQuery对象扩展方法(Extend)深度解析
- 线程同步:System.Core中新的读写锁
- ios动画
- IntelliJ IDEA 中 Project 和 Module 的概念及区别
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 为你的好朋友添点评论
- 重磅!H5游戏接入App已经解决了,民间SDK将会崛起!
- 旋转排序的数组
- 【自动化】利用webhooks自动化构建、编译Vue
- k8s prometheus的语法检查
- docker一键部署SpringBoot项目
- SpringBoot 2.3.0 新特性一览,快来跟我实践一波!
- 【腾讯】在前端开发中,如何获取浏览器的唯一标识
- 如何实现表格单双行条纹样式
- Angular 容易忽略的知识点
- 语雀自动同步到hexo博客
- 推荐 3 款超好用的 Docker 图形化管理工具
- python标准库之glob介绍
- Python 为什么只需一条语句“a,b=b,a”,就能直接交换两个变量?
- 使用List中的remove方法遇到的坑,不信你没有踩过!