91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

基于sqlalchemy對mysql實現增刪改查操作的方法

發布時間:2020-06-23 11:28:04 來源:億速云 閱讀:431 作者:清晨 欄目:MySQL數據庫

這篇文章將為大家詳細講解有關基于sqlalchemy對mysql實現增刪改查操作的方法,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

需求場景:

老大讓我利用爬蟲爬取的數據寫到或更新到mysql數據庫中,百度了兩種方法

1 是使用pymysql連接mysql,通過操作原生的sql語句進行增刪改查數據;

2 是使用sqlalchemy連接mysql,通過ORM模型建表并操作數據庫,不需要寫原生的sql語句,相對簡單些;

以下就是本次使用sqlalchemy的經驗之談。

實現流程:連接數據庫》通過模型類創建表》建立會話》執行創建表語句》通過會話進行增刪改查

from sqlalchemy import exists, Column, Integer, String, ForeignKey, exists
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker

# 創建的數據庫引擎
engine = create_engine("mysql+pymysql://user:pwd@ip/數據庫名?charset=utf8")

#創建session類型
DBSession = sessionmaker(bind=engine)

# 實例化官宣模型 - Base 就是 ORM 模型
Base = declarative_base()


# 創建服務單表
class ServiceOrder(Base):
  __tablename__ = 'serviceOrderTable'
  id = Column(Integer, primary_key=True, autoincrement=True)
  serviceOrderId = Column(String(32), nullable=False, index=True, comment='服務單ID')
  serviceDesc = Column(String(268), comment='服務說明')
  oneLevelName = Column(String(32), comment='C類別')
  twoLevelName = Column(String(32), comment='T子類')
  threeLevelName = Column(String(32), comment='I項目')
  fourLevelName = Column(String(32), comment='S子項')
  transferTimes = Column(String(32), comment='轉派次數')
  overDueStatus = Column(String(32), comment='過期狀態')
  serviceTimeLimit = Column(String(32), comment='服務時限')
  serTimeLimitTypeName = Column(String(16), comment='時限類型')  
  # 一對多:
  # serviceWorkOrder = relationship("ServiceWorkOrder", backref="serviceorder")


# 多對一:多個服務工單可以屬于服務單
class ServiceWorkOrder(Base):
  __tablename__ = 'serviceWorkOrderTable'
  id = Column(Integer, primary_key=True, autoincrement=True)
  serviceWorkOrderId = Column(String(32), nullable=False, index=True, comment='服務工單ID')
  workOrderName = Column(String(268), comment='工單名稱')
  fromId = Column(String(32), comment='服務單ID')
  createUserSectionName = Column(String(32), comment='創建人室')
  createUserName = Column(String(32), comment='創建人')
  handlerName = Column(String(32), comment='處理人')
  statusName = Column(String(32), comment='工單狀態')
  createTime = Column(String(32), comment='創建時間') 
  # “多”的一方的book表是通過外鍵關聯到user表的:
  # serviceOrder_id = Column(Integer, ForeignKey('serviceOrderTable.id'))

# 創建數據庫 如果數據庫已存在 則不會創建 會根據庫名直接連接已有的庫
def init_db():
  Base.metadata.create_all(engine)

def drop_db():
  Base.metadata.drop_all(engine)

def insert_update():
  # all_needed_data_lists 是需要插入數據庫的數據 格式[{key: value, ... }, { }, { }...]
  for item in all_needed_data_lists:
    ServiceOrderRow = ServiceOrder(serviceOrderId=item['serviceOrderId'],
                    serviceDesc=item['serviceDesc'],
                    oneLevelName=item['oneLevelName'],
                    twoLevelName=item['twoLevelName'],
                    threeLevelName=item['threeLevelName'],
                    fourLevelName=item['fourLevelName'],
                    transferTimes=item['transferTimes'],
                    overDueStatus=item['overDueStatus'],
                    serviceTimeLimit=item['serviceTimeLimit'],
                    serTimeLimitTypeName=item['serTimeLimitTypeName'],
                    )
    try:
      # 利用exists判斷目標對象是否存在,返回True或Faults
      it_exists = session.query(
          exists().where(ServiceOrder.serviceOrderId == item['serviceOrderId'] )
        ).scalar()
    except Exception as e:
      self.log.error(e)
      break
    try:
      # 如果不存在,進行新增;存在的話就更新現存的數據
      if not it_exists:
        session.add(ServiceOrderRow)
      else:
        session.query(ServiceOrder).filter(ServiceOrder.serviceOrderId == item['serviceOrderId'])\
          .update(item)
    except Exception as e:
      self.log.error(e)
      break
  try:
    session.commit()
    self.log.info('數據更新成功!')
  except:
    session.rollback()
    self.log.info('數據更新失敗!')

if __name__ == "__main__":
  # 創建數據庫 如果數據庫已存在 則不會創建 會根據庫名直接連接已有的庫
  init_db()
  # 創建session對象,進行增刪改查:
  session = DBSession()
  # 利用session 增 改數據 記得提交
  insert_update()  

關于基于sqlalchemy對mysql實現增刪改查操作的方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

都匀市| 张掖市| 廊坊市| 双江| 岐山县| 韶关市| 万安县| 微博| 威远县| 伊春市| 赤壁市| 镇宁| 临汾市| 招远市| 林州市| 荥经县| 元朗区| 宁城县| 红桥区| 观塘区| 图木舒克市| 莱阳市| 尖扎县| 会泽县| 米易县| 宜城市| 兴国县| 湘西| 什邡市| 盘山县| 闽清县| 融水| 汨罗市| 达日县| 广昌县| 玉溪市| 嘉兴市| 全州县| 娱乐| 诸暨市| 江川县|