专栏首页sktjpython flask web开发实战 DB flask-sqlalchemy

python flask web开发实战 DB flask-sqlalchemy

连接方式

MySQL mysql://username:password@hostname/database Postgres postgresql://username:password@hostname/database SQLite(Unix) sqlite:////absolute/path/to/database SQLite(Windows) sqlite:///c:/absolute/path/to/database

1、配置连接DB from flask.ext.sqlalchemy import SQLAlchemy basedir = os.path.abspath(os.path.dirname(file)) app = Flask(name) app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///' + os.path.join(basedir, 'data.sqlite') app.config['SQLALCHEMY_COMMIT_ON_TEARDOWN'] = True db = SQLAlchemy(app)

2、配置模型 db.Model db.Column class Role(db.Model): tablename = 'roles' id = db.Column(db.Integer, primary_key=True) name = db.Column(db.String(64), unique=True) def repr(self): return '<Role %r>' % self.name class User(db.Model): tablename = 'users' id = db.Column(db.Integer, primary_key=True) username = db.Column(db.String(64), unique=True, index=True) def repr(self): return '<User %r>' % self.username


在hello.py中配置导入数据库

from flask.ext.script import Shell def make_shell_context(): return dict(app=app, db=db, User=User, Role=Role) manager.add_command("shell", Shell(make_context=make_shell_context)) 3、常用列 db.Integer SmallInteger BigInteger Float Numeric String Text Unicode UnicodeText Boolean Date Time DateTime Interval 时间间隔 Enum PickleType LargeBinary 二进制文件


primary_key unique index nullable default 4、外键引用 class Role(db.Model): # ... users = db.relationship('User', backref='role', lazy='dynamic') class User(db.Model): # ... role_id = db.Column(db.Integer, db.ForeignKey('roles.id'))

relationship中的参数:

backref 在关系的另一个模型中添加反向关系 lazy select,immediate,joined,subquery,noload,dynamic uselist 是否使用列表 order_by secondary secondaryjoin 5、DB操作 db.create_all() drop_all()

添加

db.session.add()

image.png

修改也是add

image.png

删除delete

image.png

查询

Role.query.all() User.query.filter_by(role=user_role).all() user_role = Role.query.filter_by(name='User').first()

filter() filter_by() limit() offset() order_by() group_by()


all() 以列表形式返回查询的所有结果 first() 返回查询的第一个结果,如果没有结果,则返回None first_or_404() 返回查询的第一个结果,如果没有结果,则终止请求,返回404 错误响应 get() 返回指定主键对应的行,如果没有对应的行,则返回None get_or_404() 返回指定主键对应的行,如果没找到指定的主键,则终止请求,返回404 错误响应 count() 返回查询结果的数量 paginate() 返回一个Paginate 对象,它包含指定范围内的结果 6、

image.png

7、数据库操作

image.png


image.png

数据库迁移 flask-migrate

1、 from flask.ext.migrate import Migrate, MigrateCommand

...

migrate = Migrate(app, db) manager.add_command('db', MigrateCommand) 2| python hello.py db init python hello.py db migrate -m "initial migration" python hello.py db upgrade

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • flask 数据库配置(flask 25)

    from flask_sqlalchemy import SQLAlchemy WIN = sys.platform.startswith('win') i...

    用户5760343
  • flask 数据库关系(flask 28)

    class Writer(db.Model): books=db.relationship('Book',back_populates='writer') ...

    用户5760343
  • flask 邻接列表关系(flask 48)

    class Comment(db.Model): id = db.Column(db.Integer, primary_key=True) author =...

    用户5760343
  • gorm多条数据级联查询关联查询gorm连接池gorm事务

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 ...

    hotqin888
  • MongoDB日常运维操作命令小结

    总所周知,MongoDB是一个NoSQL非数据库系统,即一个数据库可以包含多个集合(Collection),每个集合对应于关系数据库中的表;而每个集合中可以存储...

    洗尽了浮华
  • flask 数据库配置(flask 25)

    from flask_sqlalchemy import SQLAlchemy WIN = sys.platform.startswith('win') i...

    用户5760343
  • flask 邻接列表关系(flask 48)

    class Comment(db.Model): id = db.Column(db.Integer, primary_key=True) author =...

    用户5760343
  • 20(数据库函数库)

    Figure 20.3. Create a database and write three records to it

    提莫队长
  • MongoDB基础语句

    MongoDB数据库安装地址:http://jingyan.baidu.com/article/d5c4b52bef7268da560dc5f8.html

    MonroeCode
  • MongoDB基础语句

    闺蜜苏苏工作是前端开发,她竟然被要求用到MongoDB数据库,所以先让她安装好先,再来测试下面语句~ MongoDB数据库安装地址:http://jingya...

    MonroeCode

扫码关注云+社区

领取腾讯云代金券