zoukankan      html  css  js  c++  java
  • 使用flask_sqlalchemy

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

    image.png

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

    1. 安装

    用pip安装即可, 进入cmd控制台输入
    pip install Flask-SQLAlchemy

    image.png


    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()
    

    image.png


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

  • 相关阅读:
    Python 的 Socket 编程教程
    java中的io系统总结
    java FileFilter的使用
    Java System 类详解 in, out, err
    电子邮件和短信将令情书绝迹
    一些有趣的编程名言
    10个经典的Android开源应用项目 android入门
    从装饰者设计模式学习Java IO
    python 求N以内的所有的质数
    java中length,length(),size()区别
  • 原文地址:https://www.cnblogs.com/we8fans/p/7107360.html
Copyright © 2011-2022 走看看