Flask基础学习2

连接mysql数据库测试(专业版)

注意1:要导入text库,否则可能出现找不到select 1错误

注意2:若出现下列问题,可按照模板代码的顺序db = SQLAlchemy(app) 的位置

RuntimeError: Either 'SQLALCHEMY_DATABASE_URI' or 'SQLALCHEMY_BINDS' must be set.

复制代码
from flask_sqlalchemy import SQLAlchemy
from sqlalchemy import text
app = Flask(__name__)

# MySQL所在主机名,默认127.0.0.1
HOSTNAME = "127.0.0.1"
PORT = 3306
USERNAME = "root"
PASSWORD = "****"
DATABASE = "***"
app.config['SQLALCHEMY_DATABASE_URI'] = f"mysql+pymysql://{USERNAME}:{PASSWORD}@{HOSTNAME}:{PORT}/{DATABASE}?charset=utf8"

db = SQLAlchemy(app)

with app.app_context():
    with db.engine.connect() as conn:
        result = conn.execute(text("select 1"))
        print(result.fetchone())  # (1,)

ORM的实现

复制代码
class User(db.Model):
    __tablename = 'admin'
    id = db.Column(db.Integer,primary_key=True,autoincrement=True)
    sname = db.Column(db.String(100),nullable=False)
    snumber = db.Column(db.String(100),nullable=False)
    address = db.Column(db.String(100),nullable=False)


with app.app_context():
    db.create_all()

命令行的实现及结果

mysql> show tables;

+---------------+

| Tables_in_flk |

+---------------+

| admin |

| user |

+---------------+

2 rows in set (0.00 sec)

mysql> desc admin;

+---------+--------------+------+-----+---------+----------------+

| Field | Type | Null | Key | Default | Extra |

+---------+--------------+------+-----+---------+----------------+

| id | int | NO | PRI | NULL | auto_increment |

| sname | varchar(100) | NO | | NULL | |

| snumber | varchar(100) | NO | | NULL | |

| address | varchar(100) | NO | | NULL | |

+---------+--------------+------+-----+---------+----------------+

4 rows in set (0.00 sec)

ORM插入实现

复制代码
user = User(sname='pass', snumber=10, address='163@qq.com')
db.session.add(user)
db.session.commit()

mysql> select * from admin;
+----+-------+---------+------------+
| id | sname | snumber | address    |
+----+-------+---------+------------+
|  1 | pass  | 10      | 163@qq.com |
+----+-------+---------+------------+
1 row in set (0.00 sec)

ORM查询实现

复制代码
user  = User.query.get(1)
print(user.sname)
# 输出 pass

ORM筛选实现

复制代码
user  = User.query.filter_by(sname='pass')
print(user[0].address)
# 输出 163@qq.com

ORM更新实现

复制代码
user  = User.query.filter_by(sname='pass').first()
user.address = '666@qq.com'
db.session.commit()

ORM删除实现

复制代码
user  = User.query.get(1)
db.session.delete(user)
db.session.commit()

其他待更新中。。。

相关推荐
Drawing stars2 小时前
JAVA后端 前端 大模型应用 学习路线
java·前端·学习
崇山峻岭之间2 小时前
Matlab学习记录33
开发语言·学习·matlab
小二·2 小时前
Python Web 开发进阶实战:性能压测与调优 —— Locust + Prometheus + Grafana 构建高并发可观测系统
前端·python·prometheus
科技林总3 小时前
【系统分析师】3.5 多处理机系统
学习
七牛云行业应用3 小时前
重构实录:我删了 5 家大模型 SDK,只留了 OpenAI 标准库
python·系统架构·大模型·aigc·deepseek
知乎的哥廷根数学学派3 小时前
基于多模态特征融合和可解释性深度学习的工业压缩机异常分类与预测性维护智能诊断(Python)
网络·人工智能·pytorch·python·深度学习·机器学习·分类
一人の梅雨4 小时前
亚马逊SP-API商品详情接口轻量化实战:合规与商业价值提取指南
python
芯思路4 小时前
STM32开发学习笔记之三【按键】
笔记·stm32·学习
charlie1145141915 小时前
从 0 开始的机器学习——NumPy 线性代数部分
开发语言·人工智能·学习·线性代数·算法·机器学习·numpy
咚咚王者5 小时前
人工智能之核心基础 机器学习 第十二章 半监督学习
人工智能·学习·机器学习