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)
- 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 数组属性和方法
- PHP实现单例模式建立数据库连接的方法分析
- 解决Python2.7中IDLE启动没有反应的问题
- PHP中mysqli_get_server_version()的实例用法
- 在unittest中使用 logging 模块记录测试数据的方法
- 分享8个Laravel模型时间戳使用技巧小结
- 基于python实现名片管理系统
- 记一个OLED编程中文显示函数的坑(留意变量数据类型的范围)
- tp5框架基于Ajax实现列表无刷新排序功能示例
- 浅谈pycharm下找不到sqlalchemy的问题
- PHP实现常用排序算法的方法
- 利用Python实现原创工具的Logo与Help
- PHP+ajax实现上传、删除、修改单张图片及后台处理逻辑操作详解
- 浅谈python下tiff图像的读取和保存方法
- Jmeter(二十五) - 从入门到精通 - JMeter函数 - 下篇(详解教程)
- 解决vscode python print 输出窗口中文乱码的问题