首先引用一下廖雪峰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. Linux指令--which,whereis,locate,find

    原文出处:http://www.cnblogs.com/peida/archive/2012/12/05/2803591.html.感谢作者无私分享 which 我们经常在linux要查找某个文件,但 ...

  2. 用 chrome 调试 node.js 代码

    1.全局安装 node-inspector  cnpm install -g node-inspector 2.启动node项目入口文件,如 node --inspect index.js 3.控制台 ...

  3. jQuery动画详解

    本文最初发表于博客园,并在GitHub上持续更新前端的系列文章.欢迎在GitHub上关注我,一起入门和进阶前端. 以下是正文. jQuery 动画 jQuery提供的一组网页中常见的动画效果,这些动画 ...

  4. Codeforce A. Fair Game

    A. Fair Game time limit per test 1 second memory limit per test 256 megabytes input standard input o ...

  5. Codeforce B. Polycarp and Letters

    B. Polycarp and Letters time limit per test 2 seconds memory limit per test 256 megabytes input stan ...

  6. final修饰符,多态,抽象类,接口

    1:final关键字(掌握)    (1)是最终的意思,可以修饰类,方法,变量.    (2)特点:        A:它修饰的类,不能被继承.        B:它修饰的方法,不能被重写.      ...

  7. String str="abc";和String str2=new String("abc");有什么区别?

  8. javascript:Json 和数组的遍历

    首先看代码示例var json={a:1,b:2,c:3}; //json var array={1,2,3}; //数组 alert(json.a); //弹出1 或alert(json['a']) ...

  9. c#控制WPF程序自动登录(Automation方式实现)

    说明:winForm窗体,可以通过win32接口dll的findWindow之类的函数来实现查找winform窗口,mfc窗口等. 但是wpf却是不实用这些,可以靠automation方式来进行操作. ...

  10. HTML5中的Web Notification桌面通知

    大家在做一些浏览器端的聊天功能的时候,或者在一些网站跟在线客服咨询的时候,会看到一些消息通知的提示,常见的有浏览器标签页的闪烁和屏幕右侧的消息通知.本篇博客就在这里简单的介绍一下如何实现这样的功能. ...