首先引用一下廖雪峰Python教程里关于sqlalchemy的话,

这里我们要讲的是flask_sqlalchemy的用法。

1. 安装

用pip安装即可, 进入cmd控制台输入

pip install Flask-SQLAlchemy


2. 引用

引用方法有2种,旧的和新的。

from flask_sqlalchemy import SQLAlchemy       # 推荐
from flask.ext.sqlalchemy import SQLAlchemy # 也能用,但是console窗口会弹出一些提示

3. 使用

声明: 参考资料出自http://www.pythondoc.com/flask-sqlalchemy/quickstart.html

http://blog.csdn.net/werewolf_st/article/details/45933949

早上做了个小的尝试,尝试将现有数据库的表转为Python的数据结构。

话不多说, 直接开干!

from flask_sqlalchemy import SQLAlchemy
from flask import Flask app = Flask(__name__)
# 此处是配置SQLALCHEMY_DATABASE_URI, 前面的mysql+mysqlconnetor指的是数据库的类型以及驱动类型
# 后面的username,pwd,addr,port,dbname分别代表用户名、密码、地址、端口以及库名
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql+mysqlconnector://username:pwd@addr:port/dbname'
# 创建1个SQLAlichemy实例
db = SQLAlchemy(app) # 定义1个类(由db.Model继承),注意这个类是数据库真实存在的,因为我是针对已有数据库做转化
# 我的数据库结构见下图 其中role是数据库的一张表名
class role(db.Model):
# id是主键db.Column是字段名, db.INT是数据类型
id = db.Column(db.INT, primary_key=True)
name = db.Column(db.String(99), unique=False)
name_cn = db.Column(db.String(99), unique=False) def __init__(self, id, name, name_cn):
self.id = id
self.name = name
self.name_cn = name_cn def __repr__(self):
return '<User %r>' % self.name # 初始化role 并插入数据库
test_role1 = role(6, 'supervisol', '超超超超级管理员哦')
test_role2 = role(7, 'your try', '你试试哦')
db.session.add(test_role1)
db.session.add(test_role2)
db.session.commit() #查询数据库
db.session.query(role).filter_by(id=2).first() # 查询role表中id为2的第一个匹配项目,用".字段名"获取字段值
db.session.query(role).all() # 得到一个list,返回role表里的所有role实例
db.session.query(role).filter(role.id == 2).first() # 结果与第一种一致
# 获取指定字段,返回一个生成器 通过遍历来完成相关操作, 也可以强转为list
db.session.query(role).filter_by(id=2).values('id', 'name', 'name_cn')
# 模糊查询
db.session.query(role).filter(role.name_cn.endswith('管理员')).all() # 获取role表中name_cn字段以管理员结尾的所有内容
# 修改数据库内容
user = db.session.query(role).filter_by(id=6).first() # 将role表中id为6的name改为change
user.name = 'change'
db.session.commit()


至于删除,我就暂时不研究啦,以后再补充~~~懒人啊哈哈哈。

使用flask_sqlalchemy的更多相关文章

  1. Flask_SqlAlchemy 1215, 'Cannot add f oreign key constraint'

    Flask_SqlAlchemy 1215, 'Cannot add f oreign key constraint'报错 sqlalchemy.exc.IntegrityError: (pymysq ...

  2. Python-Flask:利用flask_sqlalchemy实现分页效果

    Flask-sqlalchemy是关于flask一个针对数据库管理的.文中我们采用一个关于员工显示例子. 首先,我们创建SQLALCHEMY对像db. from flask import Flask, ...

  3. 解决python中flask_sqlalchemy包安装失败的问题

    在进行flask_sqlalchemy包的下载安装时出现以下问题: 由图片可看出是编码转换出了问题,找到pip\compat_init_.py文件,打开它并查看第73行,将代码做如下更改并保存: 问题 ...

  4. python flask_Sqlalchemy管理数据库

    懒癌复发直接粘贴代码,算是做一个简单备份吧. #coding:utf8 from flask import Flask from flask_sqlalchemy import SQLAlchemy ...

  5. flask_sqlalchemy的使用

    第一配置文件 # coding:utf-8 DIALECT = 'mysql' DRIVER = 'pymysql' USERNAME = 'root' PASSWORD = ' HOST = '12 ...

  6. flask_sqlalchemy

    简介: flask_sqlalchemy 是 Flask Web 框架的一个扩展. 使 Web 服务器以 (ORM: Object Relational Mapping) 对象关系映射的方式与数据库交 ...

  7. flask之flask_sqlalchemy

    一. 介绍 SQLAlchemy是一个基于Python实现的ORM框架.该框架建立在 DB API之上,使用关系对象映射进行数据库操作,简言之便是:将类和对象转换成SQL,然后使用数据API执行SQL ...

  8. flask_sqlalchemy介绍

    快速入门 Flask-SQLAlchemy 使用起来非常有趣,对于基本应用十分容易使用,并且对于大型项目易于扩展.有关完整的指南,请参阅 SQLAlchemy 的 API 文档. 一个最小应用 常见情 ...

  9. Flask 分页的简单用法 / flask_sqlalchemy /无刷新翻转页面(原创)

    flask_sqlalchemy对象提供分页方法 1. 后台views代码: from models import <table_name> #导入model的对象 @app.route( ...

随机推荐

  1. junit源码解析--测试驱动运行阶段

    前面的博客里面我们已经整理了junit的初始化阶段,接下来就是junit的测试驱动运行阶段,也就是运行所有的testXXX方法.OK,现在我们开始吧. 前面初始化junit之后,开始执行doRun方法 ...

  2. Linux指令--more,less

    文章出处:http://www.cnblogs.com/peida/archive/2012/11/05/2754477.html,感谢原作者无私的分享. more命令,功能类似 cat ,cat命令 ...

  3. java to kotlin (2) - lambda编程

    前言 Kotlin Note 是我学习kotlin整理笔记向博客,文章中的例子参考了kotlin in action这本书籍,同时我也极力推荐这本书,拥有Java基础的人可以很快的就使用kotlin来 ...

  4. 6 个 Linux 运维典型问题

    作为一名合格的 Linux 运维工程师,一定要有一套清晰.明确的解决故障思路,当问题出现时,才能迅速定位.解决问题,这里给出一个处理问题的一般思路: 重视报错提示信息:每个错误的出现,都是给出错误提示 ...

  5. centos配置单网卡为Trunk模式

    单网卡配置多IP(trunk模式)操作标准 1.linux的单网卡配置多IP的操作 下面为linux系统单网卡配置多IP(trunk模式)的操作步骤,系统平台为centos5.5.全部操作完成后,将实 ...

  6. java基础(一) 深入解析基本类型

    .   浮点数使用 IEEE(电气和电子工程师协会)格式. 浮点数类型使用 符号位.指数.有效位数(尾数)来表示.要注意一下,尾数的最高 在java中,float 和 double 的结构如下: 类 ...

  7. Single-Pass Stereo Rendering for HoloLens——HoloLens的单程立体渲染

    原文网站:https://docs.unity3d.com/Manual/SinglePassStereoRenderingHoloLens.html Single-Pass Stereo Rende ...

  8. Power shell 重启IIS

    最近根据项目需要写了一段power shell的代码 ,主要功能是批量重启IIS 具体的 Power shell 服务如下: write-output 'Restarting IIS servers ...

  9. yii 缓存之apc

    首先yii CApcCache 实现了一个针对APC的缓存应用组件,常见的缓存操作方法get,set,add,delete,flush... 下面说说配置: 1. 在config/main.php c ...

  10. hdu 4609 3-idiots [fft 生成函数 计数]

    hdu 4609 3-idiots 题意: 给出\(A_i\),问随机选择一个三元子集,选择的数字构成三角形的三边长的概率. 一开始一直想直接做.... 先生成函数求选两个的方案(注意要减去两次选择同 ...