连接方式
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