在Python的Flask框架下使用sqlalchemy库的简单教程


Posted in Python onApril 09, 2015

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()
Python 相关文章推荐
wxPython窗口中文乱码解决方法
Oct 11 Python
Python实现对一个函数应用多个装饰器的方法示例
Feb 09 Python
python+selenium实现自动抢票功能实例代码
Nov 23 Python
利用python GDAL库读写geotiff格式的遥感影像方法
Nov 29 Python
python 实现分页显示从es中获取的数据方法
Dec 26 Python
解决pyqt5中QToolButton无法使用的问题
Jun 21 Python
python文字和unicode/ascll相互转换函数及简单加密解密实现代码
Aug 12 Python
Python3 chardet模块查看编码格式的例子
Aug 14 Python
Django接收自定义http header过程详解
Aug 23 Python
Python解析json代码实例解析
Nov 25 Python
Python opencv相机标定实现原理及步骤详解
Apr 09 Python
python获取系统内存占用信息的实例方法
Jul 17 Python
详解Python中的正则表达式的用法
Apr 09 #Python
Python中几种操作字符串的方法的介绍
Apr 09 #Python
详解Python中的__new__()方法的使用
Apr 09 #Python
Python中动态获取对象的属性和方法的教程
Apr 09 #Python
详解Python中的循环语句的用法
Apr 09 #Python
python3简单实现微信爬虫
Apr 09 #Python
初步理解Python进程的信号通讯
Apr 09 #Python
You might like
php 静态化实现代码
2009/03/20 PHP
php5 apache 2.2 webservice 创建与配置(java)
2011/01/27 PHP
PHP中SimpleXML函数用法分析
2014/11/26 PHP
PHP判断是否连接上网络的方法
2015/07/01 PHP
php模仿qq空间或朋友圈发布动态、评论动态、回复评论、删除动态或评论的功能(中)
2017/06/11 PHP
JS 学习笔记 防止发生命名冲突
2009/07/30 Javascript
如何解决Jquery库及其他库之间的$命名冲突
2013/09/15 Javascript
setTimeout自动触发一个js的方法
2014/01/15 Javascript
在百度知道团队中快速审批新成员的js脚本
2014/02/02 Javascript
动态JavaScript所造成一些你不知道的危害
2016/09/25 Javascript
bootstrap select2插件用ajax来获取和显示数据的实例
2018/08/09 Javascript
vue-cli构建vue项目的步骤详解
2019/01/27 Javascript
Vuejs中的watch实例详解(监听者)
2020/01/05 Javascript
[42:06]2019国际邀请赛全明星赛 8.23
2019/09/05 DOTA
python中map、any、all函数用法分析
2015/04/21 Python
深入剖析Python的爬虫框架Scrapy的结构与运作流程
2016/01/20 Python
Pycharm代码无法复制,无法选中删除,无法编辑的解决方法
2018/10/22 Python
Python补齐字符串长度的实例
2018/11/15 Python
Python-ElasticSearch搜索查询的讲解
2019/02/25 Python
浅谈Django中view对数据库的调用方法
2019/07/18 Python
如何在VSCode上轻松舒适的配置Python的方法步骤
2019/10/28 Python
Pytorch GPU显存充足却显示out of memory的解决方式
2020/01/13 Python
计算机应用专业推荐信
2013/11/13 职场文书
经理秘书找工作求职信
2013/12/19 职场文书
婚礼证婚人证婚词
2014/01/08 职场文书
银行学习十八大感想
2014/01/11 职场文书
学雷锋宣传标语
2014/06/25 职场文书
办公室主任个人对照检查材料思想汇报
2014/10/11 职场文书
收银员岗位职责
2015/02/03 职场文书
天下第一关导游词
2015/02/06 职场文书
个性发展自我评价2015
2015/03/09 职场文书
毕业生入职感言
2015/07/31 职场文书
幼儿园小班教育随笔
2015/08/14 职场文书
2016年情人节问候语
2015/11/11 职场文书
浅谈mysql增加索引不生效的几种情况
2021/06/23 MySQL
Nginx使用ngx_http_upstream_module实现负载均衡功能示例
2022/08/05 Servers