SQLAlchemy的ORM(2)

Column常用参数:

  • default:默认值。
  • server_default:数据库默认值,只接收字符串。设置该值后,可配置到数据库中。
  • nullable:是否可空。
  • primary_key:是否为主键。
  • unique:是否唯一。
  • autoincrement:是否自动增长。
  • onupdate:更新的时候执行的函数。
  • name:该属性在数据库中的字段映射。

    sqlalchemy常用数据类型:

  • Integer:整形。

  • Float:浮点类型。
  • Boolean:传递True/False进去。
  • DECIMAL:定点类型。
  • enum:枚举类型。
  • Date:传递datetime.date()进去。
  • DateTime:传递datetime.datetime()进去。
  • Time:传递datetime.time()进去。
  • String:字符类型,使用时需要指定长度,区别于Text类型。
  • Text:文本类型。
  • LONGTEXT:长文本类型。

    query可用参数:

  1. 模型对象。指定查找这个模型中所有的对象。
  2. 模型中的属性。可以指定只查找某个模型的其中几个属性。
  3. 聚合函数。

    • func.count:统计行的数量。
    • func.avg:求平均值。
    • func.max:求最大值。
    • func.min:求最小值。
    • func.sum:求和。

      过滤条件:

      过滤是数据提取的一个很重要的功能,以下对一些常用的过滤条件进行解释,并且这些过滤条件都是只能通过filter方法实现的:
  4. equals

    1. query.filter(User.name == 'ed')
  5. not equals:

    1. query.filter(User.name != 'ed')
  6. like

    1. query.filter(User.name.like('%ed%'))
  7. in

    1. query.filter(User.name.in_(['ed','wendy','jack']))
    2. # 同时,in也可以作用于一个Query
    3. query.filter(User.name.in_(session.query(User.name).filter(User.name.like('%ed%'))))
  8. not in

    1. query.filter(~User.name.in_(['ed','wendy','jack']))
  9. is null

    1. query.filter(User.name==None)
    2. # 或者是
    3. query.filter(User.name.is_(None))
  10. is not null:

    1. query.filter(User.name != None)
    2. # 或者是
    3. query.filter(User.name.isnot(None))
  11. and

    1. from sqlalchemy import and_
    2. query.filter(and_(User.name=='ed',User.fullname=='Ed Jones'))
    3. # 或者是传递多个参数
    4. query.filter(User.name=='ed',User.fullname=='Ed Jones')
    5. # 或者是通过多次filter操作
    6. query.filter(User.name=='ed').filter(User.fullname=='Ed Jones')
  12. or

    1. from sqlalchemy import or_ query.filter(or_(User.name=='ed',User.name=='wendy'))