專欄:012:沒時間解釋了,快使用sqlalchemy

用理工科思維看待這個世界

系列爬蟲專欄

崇尚的學(xué)習(xí)思維是:輸入,輸出平衡,且平衡點不斷攀升。

今天的主題是:sqlalchemy的使用(這是一篇沒有真正實戰(zhàn)的博文)


0:框架

序號 內(nèi)容 說明
01 概念解釋 是什么?
02 代碼解釋 怎么做?
03 總結(jié) 如何做的?

1:概念

  • ORM
    對象關(guān)系映射(英語:Object Relational Mapping,簡稱ORM,或O/RM,或O/R mapping),是一種程序設(shè)計技術(shù),用于實現(xiàn)面向?qū)ο缶幊陶Z言里不同類型系統(tǒng)的數(shù)據(jù)之間的轉(zhuǎn)換。

圖片顯示:對象和數(shù)據(jù)庫之間的映射

1462796986482.png

原理:

1462797367071.png
  • SQLAlchemy
    是python的一款開源軟件,提供了SQL工具包及對象關(guān)系映射(ORM)工具。(需要安裝第三方庫)
    官方文檔

  • 為什么會出現(xiàn)這種技術(shù)?
    一句話解釋:為了避免寫繁復(fù)的sql語句.(隱藏數(shù)據(jù)庫,良好的數(shù)據(jù)接口,動態(tài)的數(shù)據(jù)映射,引入緩存)


2:代碼解釋

一般步驟:

  • 創(chuàng)建連接
  • 聲明映射文件
  • 創(chuàng)建模式
  • 初始化映射類實例
  • 創(chuàng)建回話
  • 持久化實例對象

1:創(chuàng)建連接

from sqlalchemy import create_engine
engine = create_engine("mysql://root:123456@localhost:3306/test?charset=utf8", echo = True)

# echo= True 會打印操作數(shù)據(jù)庫的信息

Database_urls 的組成形式:
dialect+driver://username:password@host:port/database
舉例:

  1. mysql://root:123456@localhost:3306/test
  2. postgresql://scott:tiger@localhost/mydatabase
  3. oracle://scott:tiger@127.0.0.1:1521/sidname
  4. sqlite:///foo.db
    具體參見:點我點我

2:聲明映射文件

from sqlalchemy.ext.declarative import declarative_base
Base = declarative_base()
from sqlalchemy import Column, Integer, String
class User(Base):
    __tablename__ = 'users'
    id = Column(Integer, primary_key=True)
    name = Column(String(10))
    password = Column(String(10))

    def __repr__(self):
        return "<User(name='%s', name='%s', password='%s')>" % (self.name, self.name, self.password)

# 以上聲明了表文件的形式:表名為:users, 包含3列:id, name, password,且定義了數(shù)據(jù)類型

3:創(chuàng)建數(shù)據(jù)庫表

User.metadata.create_all(engine)
# 運行后會在本地mysql數(shù)據(jù)庫中創(chuàng)建這個數(shù)據(jù)庫表

---
結(jié)果顯示:
2016-05-09 20:52:38,062 INFO sqlalchemy.engine.base.Engine SHOW VARIABLES LIKE 'sql_mode'
2016-05-09 20:52:38,091 INFO sqlalchemy.engine.base.Engine ()
2016-05-09 20:52:38,094 INFO sqlalchemy.engine.base.Engine SELECT DATABASE()
2016-05-09 20:52:38,094 INFO sqlalchemy.engine.base.Engine ()
2016-05-09 20:52:38,114 INFO sqlalchemy.engine.base.Engine show collation where `Charset` = 'utf8' and `Collation` = 'utf8_bin'
2016-05-09 20:52:38,114 INFO sqlalchemy.engine.base.Engine ()
2016-05-09 20:52:38,116 INFO sqlalchemy.engine.base.Engine SELECT CAST('test plain returns' AS CHAR(60)) AS anon_1
2016-05-09 20:52:38,117 INFO sqlalchemy.engine.base.Engine ()
2016-05-09 20:52:38,127 INFO sqlalchemy.engine.base.Engine SELECT CAST('test unicode returns' AS CHAR(60)) AS anon_1
2016-05-09 20:52:38,128 INFO sqlalchemy.engine.base.Engine ()
2016-05-09 20:52:38,158 INFO sqlalchemy.engine.base.Engine SELECT CAST('test collated returns' AS CHAR CHARACTER SET utf8) COLLATE utf8_bin AS anon_1
2016-05-09 20:52:38,158 INFO sqlalchemy.engine.base.Engine ()
2016-05-09 20:52:38,160 INFO sqlalchemy.engine.base.Engine DESCRIBE `users`
2016-05-09 20:52:38,160 INFO sqlalchemy.engine.base.Engine ()
2016-05-09 20:52:38,168 INFO sqlalchemy.engine.base.Engine ROLLBACK
2016-05-09 20:52:38,170 INFO sqlalchemy.engine.base.Engine 
CREATE TABLE users (
    id INTEGER NOT NULL AUTO_INCREMENT, 
    name VARCHAR(10), 
    password VARCHAR(10), 
    PRIMARY KEY (id)
)


2016-05-09 20:52:38,171 INFO sqlalchemy.engine.base.Engine ()
2016-05-09 20:52:38,655 INFO sqlalchemy.engine.base.Engine COMMIT

數(shù)據(jù)庫test中生成表數(shù)據(jù):

1462798497039.png

4:創(chuàng)建會話

from sqlalchemy.orm import sessionmaker
Session = sessionmaker(bind=engine)
session = Session()

5:持久化實例對象

ed_user = User(id=1, name='xiexiaolu', password='dianwo')
session.add(ed_user)
session.commit()

數(shù)據(jù)顯示:插入一條數(shù)據(jù)

1462798847878.png
# 查詢操作
user=session.query(User).filter(User.id ==1).one()
print(user.name)
print(user.password)
# output: id =1 的數(shù)據(jù)的 name 和 password
xiexiaolu
dianwo

創(chuàng)建數(shù)據(jù)表的其他方式


from sqlalchemy import Table, MetaData, create_engine

engine = create_engine("mysql+mysqlconnector://root:123456@localhost:3306/test")
metadata = MetaData()

t1 = Table('users',
metadata,
Column('id',INT, primary_key=True),
Column('name', String(20)),
Column('fullname', String(50)),
Column('password', String(20))
) 
t2 = Table('address',
metadata, 
Column('id',INT, primary_key = True), 
Column('email_address',String(50), nullable=False),
Column('user_id', INT, ForeignKey('users.id'))
) 
metadata.create_all(engine)
# 創(chuàng)建兩個數(shù)據(jù)表分別為users 和 address

插入數(shù)據(jù)的其他方式

# 在建立的會話基礎(chǔ)上執(zhí)行sql語句
session.execute('insert into users values(2,"Bob","budian")')
session.commit()

# 使用映射類成員變量的數(shù)據(jù)
user = User(id="3", name="alice", password="hgf")
session.add(user)
session.commit()

查詢操作

users = session.query(User).all()# 返回數(shù)據(jù)表所有數(shù)據(jù)

修改數(shù)據(jù)

# 在會話的基礎(chǔ)上執(zhí)行sql語句
session.execute('update addresses set user_id = 1 where id = 2')
session.commit()

# 使用映射類成員變量的數(shù)據(jù)
session.query(Address).filter(Address.id == 2).update({"user_id": 1})

3:總結(jié)

參考文獻(xiàn):
參考文獻(xiàn)
參考文獻(xiàn)
參考文獻(xiàn)

一切為了精進(jìn).


新搭建的博客:Xie-xiaolu
預(yù)覽界面:

1462802927993.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容