在Python的Flask框架下使用sqlalchemy库的简单教程
作者:zengchenacmer 发布时间:2021-02-23 23:58:40
flask中的sqlalchemy 相比于sqlalchemy封装的更加彻底一些 , 在一些方法上更简单
首先import类库:
在CODE上查看代码片派生到我的代码片
<span style="font-size:18px;">from flask import Flask
from flask.ext.sqlalchemy import SQLAlchemy</span>
然后,需要加载 数据库路径
在CODE上查看代码片派生到我的代码片
<span style="font-size:18px;">mysqlname='<span style="color: rgb(230, 219, 116); font-family: 'Source Code Pro'; font-size: 13pt; background-color: rgb(39, 40, 34);">mysql://user:passwd@127.0.0.1/student?charset=utf8</span>'</span>
在CODE上查看代码片派生到我的代码片
<span style="font-size:18px;">app = Flask(__name__)
app.config['SQLALCHEMY_DATABASE_URI'] = mysqlname
db = SQLAlchemy(app)</span>
通过前面两步 ,我们已经让flask和数据库联系到了一起
下面我们要把 flask和具体的表联系在一起、
这样建立一个model模型
在CODE上查看代码片派生到我的代码片
<span style="font-size:18px;">class User(db.Model):
"""存储 每种报警类型的数量 , 以 分钟 为单位进行统计
:param source: string ,报警来源
:param network_logic_area: string ,该报警所属的逻辑网络区域
:param start_time: datetime , 报警发生时间
"""
__tablename__ = 'hello'
id = db.Column(db.Integer , primary_key = True)
source = db.Column(db.String(255) )
network_logic_area = db.Column(db.String(255) )
start_time = db.Column(db.DateTime)
count = db.Column(db.Integer)
def __init__(self , source , network_logic_area , start_time , count):
self.source = source
self.network_logic_area = network_logic_area
self.start_time = start_time
self.count = count
def alter(self):
self.count += 1;</span>
上面这个代码,就让falsk和具体的表hello联系在了一起
在这个类中 ,我们首先要指定表,然后把这个表中的列都列出来,最后定义一个 初始化函数 , 让后面插入数据使用
现在开始具体的数据库操作:
1、insert
在CODE上查看代码片派生到我的代码片
<span style="font-size:18px;"> p = User(........)
db.session.add(p)
db.session.commit()</span>
通过 类User构造了一条数据
2、find
用主键获取数据:
Code example:
User.query.get(1)
<User
u'admin'>
通过一个精确参数进行反查:
Code example:
peter
=
User.query.filter_by(username='peter').first()
#注意:精确查询函数query.filter_by(),是通过传递参数进行查询;其他增强型查询函数是query.filter(),通过传递表达式进行查询。
print(peter.id)
#如果数据不存在则返回None
模糊查询:
Code example:
User.query.filter(User.email.endswith('@example.com')).all()
[<User
u'admin'>,
<User u'guest'>]
逻辑非1:
Code example:
peter
=
User.query.filter(User.username
!=
'peter').first()
print(peter.id)
逻辑非2:
Code example:
from
sqlalchemy import
not_
peter
=
User.query.filter(not_(User.username=='peter')).first()
print(peter.id)
逻辑与:
Code example:
from
sqlalchemy import
and_
peter
=
User.query.filter(and_(User.username=='peter',
User.email.endswith('@example.com'))).first()
print(peter.id)
逻辑或:
Code example:
from
sqlalchemy import
or_
peter
=
User.query.filter(or_(User.username
!=
'peter',
User.email.endswith('@example.com'))).first()
print(peter.id)
filter_by:这个里面只能放具体放入条件,不能放一个复杂的计算 ,
filter: 这个里面可以放一些复杂的计算
.first:取第一条数据
.all:取出所有数据
还有一个其他的方法,可以进行排序、计数之类的操作
3、使用sql语句
可以通过 前面构造的 db 直接使用sql的原生语句
在CODE上查看代码片派生到我的代码片
<span style="font-size:18px;">insert_table.db.engine.execute(' ..... ')</span>
4、delete
在CODE上查看代码片派生到我的代码片
<span style="font-size:18px;">me = User(........)</span>
在CODE上查看代码片派生到我的代码片
<span style="font-size:18px;">db.session.delete(me)
db.session.commit()</span>
5、更新数据
Code example:
u
=
User.query.first()
u.username
=
'guest'
#更新数据和变量赋值那么简单,但必须是通过查询返回的对象。
db.session.commit()


猜你喜欢
- 批量修改: EXEC sp_MSforeachtable 'exec sp_changeob
- php获取图片的exif信息,php自带一个exif_read_data函数可以用来读取图片的exif信息,代码来自php手册<?ph
- Apple4.us的张亮问我:“很多人说用户体验是苹果的核心竞争力。在用户体验方面,我究竟该从苹果的设计中学习什么” ?关于这个问题的答案我
- 如何要恢复Master数据库呢?方法1:重装SQL,但是数据就Over掉了方法2:重建Master Rebuildm.exe 用到SQL的安
- 查看当前用户拥有的系统权限 select * from user_sys_privs; 系统权限 系统管理员授予-----sys用户 cre
- JavaScript图片水平翻转后垂直翻反转的特效一:<!--把下列代码加到body区域内--><SCRIPT langu
- list/tuple转置:以二维grid[][]为例:grid = [[row[i] for row in grid] for i in r
- keras训练fit( self, x, y, batch_size=32, nb_epoch=10, verbose=1, c
- Vue加载流程1.初始化的第一阶段是Vue实例也就是vm对象创建前后:首先Vue进行生命周期,事件初始化发生在beforeCreate生命周
- 首先,"/"左倾斜是正斜杠,"\"右倾斜是反斜杠,可以记为:除号是正斜杠一般来说对于目录分隔符,Un
- Python中函数参数的定义主要有四种方式:1. F(arg1,arg2,…)这是最常见的定义方式,一个函数可以定义任意个参数,每个参数间用
- 简介:MongoEngine 是一个Document-Object Mapper (想一下ORM, 但它是针对文档型数据库),Python通
- js代码:$(".head").change(function() {var val = $(this).val();i
- 安装 Java 语言的软件开发工具包brew cask install java或者在Oracle官网 中选择 Mac 版本 jdk-8u1
- 前言Go大概2009年面世以来,已经8年了,也算是8年抗战。在这8年中,已经有很多公司开始使用Go语言开发自己的服务,甚至完全转向Go开发,
- 1、数值类型1.1、数值类型分类严格数值类型(INTEGER、SMALLINT、DECIMAL 和 NUMERIC)近似数值数据类型(FLO
- 在项目中,尤其是pc端的时候,我们在用户登录后会给前端返回一个标识,来判断用户是否登录,这个标识大多数都是用户的id  
- 模块a.py 想用 b.py中公有数据 cntb的python文件#!/usr/bin/env python# coding:utf8fro
- 1.django自定义字段类型,实现非主键字段的自增# -*- encoding: utf-8 -*-from django.db.mode
- mysql对列求和mysql中,可以使用SELECT语句配合SUM()函数来对列求和,能够返回指定列值的总和,求和语法为&ldquo