Flask中之数据库框架和模型类一:SQLAlchemy配置说明,字段类型,约束条件
admin
2023-07-20 10:02:22
0

Python数据库框架

#  pip install flask-sqlalchemy****
    数据库引擎              URL
   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

#  在这些 URL 中,hostname 表示 MySQL 服务所在的主机,可以是本地主机(localhost),
# 也可以是远程服务器。数据库服务器上可以托管多个数据库,因此 database 表示要使用的
#  数据库名。如果数据库需要进行认证,username 和 password 表示数据库用户密令。
#  示例  hello.py:配置数据库
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)
#  db 对象是 SQLAlchemy 类的实例,表示程序使用的数据库,同时还获得了 Flask-SQLAlchemy
# 提供的所有功能。
# 定义模型
示例 5-2 hello.py:定义 Role 和 User 模型
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 '' % 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 '' % self.username
#  类变量 __tablename__ 定义在数据库中使用的表名。
#  如果没有定义 __tablename__,Flask-SQLAlchemy 会使用一个默认名字,
#  但默认的表名没有遵守使用复数形式进行命名的约定,
#  所以最好由我们自己来指定表名。其余的类变量都是该模型的属性,被定义为#  db.Column
#  类的实例。
#  db.Column 类构造函数的第一个参数是数据库列和模型属性的类型。
    类型名                  Python类型                     说  明
Integer                   int 普通整数,              一般是 32 位
SmallInteger          int 取值范围小的整数   一般是 16 位
BigInteger              int 或 long                    不限制精度的整数
Float                      float                              浮点数
Numeric                decimal.Decimal           定点数
String                    str                                 变长字符串
Text                       str               变长字符串,对较长或不限长度的字符串做了优化
Unicode                 unicode                    变长 Unicode 字符串
UnicodeText         unicode                对较长或不限长度的字符串做了优化
Boolean                 bool                           布尔值
Date                    datetime.date               日期
Time                    datetime.time               时间
DateTime           datetime.datetime          日期和时间
Interval                datetime.timedelta          时间间隔
Enum                   str                                   一 组字符串
PickleType           任何 Python 对象           自动使用 Pickle 序列化
LargeBinary         str                                   二进制文件
#  最常使用的SQLAlchemy列选项,也即约束条件

primary_key         如果设为 True,这列就是表的主键
unique                  如果设为 True,这列不允许出现重复的值
index                   如果设为 True,为这列创建索引,提升查询效率
nullable                如果设为 True,这列允许使用空值;如果设为 False,这列不允许使用空值
default                 为这列定义默认值
doc                      字段说明 

# Flask-SQLAlchemy 要求每个模型都要定义主键,这一列经常命名为 id。

相关内容

热门资讯

云南永善通报两名公职人员涉嫌违... 澎湃新闻记者 朱远祥云南永善两名公职人员因涉嫌违法被查,其中一人酒后驾车,另一人参与赌博。6月18日...
极速达,害了山姆 山姆,最近的事有点多。6月15日,国家市场监督管理总局通报,针对一段时期以来发现的山姆线下门店及线上...
万斯暂不赴瑞士谈判,伊朗强调黎... 据凤凰卫视报道,美国白宫表示,由于美国和伊朗下一阶段谈判的后勤安排尚未敲定,美国副总统万斯将不再按原...
河南牧业经济学院开展“执笔题香... 仲夏迎端午,雅韵满校园。6 月 11 日,河南牧业经济学院 “执笔题香佩 拈韵赋端阳” 端午主题文化...
花栖成境 自在湾居 | 铁建投... 2026 年 6 月 13 日,铁建投城发・花栖樾内高朋云集、雅士齐聚。备受全城瞩目的会呼吸的河岸生...
社群自己“长”起来:越秀中西部... 社区是城市最小的聚落单元,那么社群,便是这片土地上自发生长出的情感共同体。这份对邻里情感的珍视,是越...
中原润府一周年项目白皮书发布,... 当前,购房者的顾虑集中在三个层面:能否如期交付?实景是否与承诺一致?物业和社区运营能否跟上?这些担忧...
六国化工获得实用新型专利授权:... 证券之星消息,根据天眼查APP数据显示六国化工(600470)新获得一项实用新型专利授权,专利名为“...
端午送温情 敬老暖人心 黄河科... 在2026年端午节来临之际,黄河科技学院工会、关工委精心组织开展学校退休教职工端午慰问活动,为大家统...