python之SQLAchemy、paramiko

來源:互聯網
上載者:User

標籤:

SQLAchemy

SQLAlchemy是Python程式設計語言下的一款ORM架構,該架構建立在資料庫API之上,使用關聯性物件映射進行資料庫操作,簡言之便是:將對象轉換成SQL,然後使用資料API執行SQL並擷取執行結果。

一、底層處理

使用 Engine/ConnectionPooling/Dialect 進行資料庫操作,Engine使用ConnectionPooling串連資料庫,然後再通過Dialect執行SQL語句。

#!/usr/bin/env python# -*- coding:utf-8 -*-from sqlalchemy import create_engine  engine = create_engine("mysql+pymysql://root:[email protected]:3306/t1", max_overflow=5) # 執行SQL# cur = engine.execute(#     "INSERT INTO hosts (host, color_id) VALUES (‘1.1.1.22‘, 3)"# ) # 新插入行自增ID# cur.lastrowid # 執行SQL# cur = engine.execute(#     "INSERT INTO hosts (host, color_id) VALUES(%s, %s)",[(‘1.1.1.22‘, 3),(‘1.1.1.221‘, 3),]# )  # 執行SQL# cur = engine.execute(#     "INSERT INTO hosts (host, color_id) VALUES (%(host)s, %(color_id)s)",#     host=‘1.1.1.99‘, color_id=3# ) # 執行SQL# cur = engine.execute(‘select * from hosts‘)# 擷取第一行資料# cur.fetchone()# 擷取第n行資料# cur.fetchmany(3)# 擷取所有資料# cur.fetchall()

二、ORM

使用 ORM/Schema Type/SQL Expression Language/Engine/ConnectionPooling/Dialect 所有組件對資料進行操作。根據類建立對象,對象轉換成SQL,執行SQL。

#!/usr/bin/env python# -*- coding: UTF-8 -*-from sqlalchemy import create_enginefrom sqlalchemy.ext.declarative import declarative_basefrom sqlalchemy import Column, Integer, String, ForeignKey, UniqueConstraint, Indexfrom sqlalchemy.orm import sessionmaker, relationshipengine = create_engine("mysql+pymysql://root:[email protected]:3306/s13", max_overflow=5)Base = declarative_base()# 建立表class Test(Base):    __tablename__ = ‘test‘    nid = Column(Integer,primary_key=True,autoincrement=True)    name = Column(String(32))# 一對多class Group(Base):    __tablename__ = ‘group‘    nid = Column(Integer, primary_key=True, autoincrement=True)    name = Column(String(32))class Users(Base):    __tablename__ = ‘user‘    nid = Column(Integer,primary_key=True,autoincrement=True)    name = Column(String(32))    group_id = Column(Integer,ForeignKey(‘group_nid‘))    def __repr__(self):        temp = ‘%s - %s - %s‘%(self.nid,self.username,self.group_id)        return tempdef init_db():    Base.metable.create_all(engine)def drop_db():    Base.metable.drop_all(engine)Session = sessionmaker(bind=engine)session = Session()

動作表

 1 #定義一個欄位 2 add = User(id=2, name=‘mxz‘) 3 #添加欄位 4 session.add(add) 5 #添加多個欄位 6 session.add_all([ 7     User(id=3, name=‘aaa‘), 8     User(id=4, name=‘bbb‘) 9 ])10 #提交以上操作11 session.commit()

==================================================================

1 #刪除user表,id大於2的欄位2 session.query(User).filter(User.id > 2).delete()3 session.commit()

==================================================================

1 在執行以下操作2 #user表裡的id等於2的欄位修改為id=63 session.query(User).filter(User.id == 2).update({‘id‘ : 6})4 session.commit()

==================================================================

1 # 查詢users表下面所有的欄位2 ret = session.query(Users).all()3 4 ret = session.query(Users.name, Users.extra).all()5 # 查詢users表下面所有name=mxz的欄位6 ret = session.query(Users).filter_by(name=‘mxz‘).all()7 # 查詢users表下面第一個name=mxz的欄位8 ret = session.query(Users).filter_by(name=‘mxz‘).first()

 

python之SQLAchemy、paramiko

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.