当前位置: 首页 > news >正文

宁波城乡建设局网站学生个人网页制作成品

宁波城乡建设局网站,学生个人网页制作成品,郑州网站建设哪家公司好,企业邮箱收费吗目录 Column常用参数 代码演示 代码刨析 query函数的使用 基本用法 常见用法示例 查询所有记录 根据条件查询 查询第一条符合条件的记录 查询特定列的值 添加排序规则 使用聚合函数 连接查询 使用filter_by Column常用参数 primary_key:True设置某个字…

目录

Column常用参数

代码演示

 代码刨析

query函数的使用

基本用法

常见用法示例

查询所有记录

根据条件查询

查询第一条符合条件的记录

查询特定列的值

添加排序规则

使用聚合函数

连接查询 

使用filter_by


Column常用参数

  • primary_key:True设置某个字段为主键。

class User(Base):__tablename__ = 'users'id = Column(Integer, primary_key=True)
  • autoincrement:True设置这个字段为自动增长的。

from sqlalchemy import Column, Integer, Stringclass User(Base):__tablename__ = 'users'id = Column(Integer, primary_key=True, autoincrement=True)username = Column(String(50))
  • default:设置某个字段的默认值。在发表时间这些字段上面经常用。

class User(Base):__tablename__ = 'users'id = Column(Integer, primary_key=True)status = Column(String(20), default='active')
  • nullable:指定某个字段是否为空。默认值是True,就是可以为空。

class User(Base):__tablename__ = 'users'id = Column(Integer, primary_key=True)name = Column(String(50), nullable=False)
  • unique:指定某个字段的值是否唯一。默认是False。

class User(Base):__tablename__ = 'users'id = Column(Integer, primary_key=True)email = Column(String(100), unique=True)
  • onupdate:在数据更新的时候会调用这个参数指定的值或者函数。在第一次插入这条数据的时候,不会用onupdate的值,只会使用default的值。常用于是update_time字段(每次更新数据的时候都要更新该字段值)。

from sqlalchemy import Column, Integer, String, DateTime, funcclass User(Base):__tablename__ = 'users'id = Column(Integer, primary_key=True)username = Column(String(50))last_updated = Column(DateTime, onupdate=func.now())
  • server_default(服务器端默认值):在数据库层面设置默认值,而不是在Python代码层面。

from sqlalchemy import textclass User(Base):__tablename__ = 'users'id = Column(Integer, primary_key=True)created_at = Column(DateTime, server_default=text('CURRENT_TIMESTAMP'))
  • index(索引):指定是否为该列创建索引,以提高检索速度。

class User(Base):__tablename__ = 'users'id = Column(Integer, primary_key=True)username = Column(String(50), index=True)
  • name:指定ORM模型中某个属性映射到表中的字段名。如果不指定,那么会使用这个属性的名字来作为字段名。如果指定了,就会使用指定的这个值作为表字段名。这个参数也可以当作位置参数,在第1个参数来指定。

title = Column(String(50),name='title',nullable=False)
title = Column('my_title',String(50),nullable=False)

代码演示

from datetime import datetimefrom sqlalchemy import Column,Integer,DateTime,Stringfrom db_util import Base,Sessionclass News(Base):__tablename__ = 't_news2'id = Column(Integer,primary_key = True,autoincrement = True)phone = Column(String(11),unique = True)title = Column(String(32),nullable = False)read_count = Column(Integer,default=1)create_time = Column(DateTime,default = datetime.now)update_time = Column(DateTime,default = datetime.now, onupdate =datetime.now ) # 当数据更新后,参数的内容才会更改def create_data():new1 = News(phone='16866666666',title='测试列参数')with Session() as session:session.add(new1)session.commit()def create_data2():# new1 = News(phone='16866666666',title='测试列参数') # 不允许重复# new1 = News(phone='16866666668') # title不能为空# with Session() as session:#   session.add(new1)#   session.commit()with Session() as session:new1 = session.query(News).first()  new1.read_count = 2session.commit()if __name__ == '__main__':# Base.metadata.create_all()# create_data()create_data2()

 代码刨析

  1. id: 主键列,自动递增。
  2. phone: 字符串类型,长度为11,唯一约束。
  3. title: 字符串类型,最大长度为32,不能为空。
  4. read_count: 整数类型,有一个默认值为1。
  5. create_time: 日期时间类型,有一个默认值为当前时间。
  6. update_time: 日期时间类型,有一个默认值为当前时间,并且在更新时会自动更新为新的时间。

这个脚本中还包含了两个函数 create_data()create_data2(),它们用于向数据库中插入数据。

create_data2() 函数中,首先获取了表中的第一个记录,然后将其read_count修改为2,并提交了事务。

请注意,在这个代码中,onupdate=datetime.now 表示在记录更新时,update_time 会被自动更新为当前时间。

query函数的使用

query 函数是 SQLAlchemy 中用于执行数据库查询操作的方法。它通常用于从数据库中检索数据。

基本用法

session.query(ModelClass)

这里的 ModelClass 定义的模型类,它对应了数据库中的表格。query 函数将返回一个查询对象,可以在该对象上继续添加过滤条件、排序规则等,最终执行查询操作以获取符合条件的数据。

常见用法示例

查询所有记录

result = session.query(User).all()

根据条件查询

result = session.query(User).filter(User.name == 'John').all()

查询第一条符合条件的记录

result = session.query(User).filter(User.name == 'John').first()

查询特定列的值

result = session.query(User.name, User.email).all()

添加排序规则

result = session.query(User).order_by(User.name).all()

使用聚合函数

from sqlalchemy import funcresult = session.query(func.count(User.id)).scalar()

连接查询 

result = session.query(User, Address).join(Address, User.id == Address.user_id).all()

使用filter_by

result = session.query(User).filter_by(name='John').all()

http://www.shuangfujiaoyu.com/news/42522.html

相关文章:

  • 石家庄网站开发价格各行业关键词
  • wordpress视频大小自由适配屏幕浙江seo外包费用
  • 快速web网站开发小说排行榜百度搜索风云榜
  • 建行官网的网址网站推广优化怎么做最好
  • 杭州专业做网站海外推广服务
  • 网站建设中英文版个人能接广告联盟吗
  • 做网站是不是很麻烦三门峡网站seo
  • 有个新网站专门做外贸的叫什么网站推广优化c重庆
  • 昌平知名的网站制作建设报价廊坊seo外包公司费用
  • 厦门有设计网站的吗谈谈自己对市场营销的理解
  • 滨州网站建设 远洋科技沈阳百度快照优化公司
  • 做网站大图片青岛网站优化公司
  • 励销云seo搜索引擎优化主要做什么
  • 浏览器怎么连接网站的网站seo外包公司有哪些
  • 赤峰做网站哪家好常见搜索引擎有哪些
  • 泉州手机网站建设价格深圳seo排名优化
  • 一级域名做网站的好处外贸企业网站推广
  • 网站建设色彩嘉兴优化公司
  • 自己做图片的网站吗武汉seo托管公司
  • 关于做网站的外语文献刷粉网站推广快点
  • 合肥做网站加盟公司网站推广怎么做
  • 网站布局策划正规推广平台
  • 模板做图 网站seo智能优化公司
  • 茶叶官网网站建设杭州百度竞价推广公司
  • 印度网站建设有了域名如何建立网站
  • 计算机网络技术网站开发与设计国际热点事件
  • 清溪网站仿做安徽seo团队
  • 网站做好了 怎么做解析石家庄疫情太严重了
  • 个人建网站需要多少钱百度官网登录入口
  • 公司网站修改 优帮云推动防控措施持续优化