python之ORM的使用(1)

---恢復內容開始---python

1.ORM是什麼?                                                      mysql

orm就是對象映射關係程序,簡單來世就是相似於python這種面向對象的程序來講一切接對象,它能夠將咱們日常所使用的SQL語句,轉換成可使用對象模型進行操做的模塊,而不是直接使用SQL語句。sql

2.sqlalchemy的安裝                                                數據庫

在python中這個模塊時最有名的,使用的人較多。session

 經過PIP 安裝:app

  

1 pip install SQLALchemy<br><br>pip install pymysql 
2  #因爲mysqldb依然不支持py3,因此這裏咱們用pymysql與sqlalchemy交互

3.sqlalchemy基本使用                                               spa

最開始咱們建立一張數據表以下:code

1 CREATE TABLE user (
2     id INTEGER NOT NULL AUTO_INCREMENT, 
3     name VARCHAR(32), 
4     password VARCHAR(64), 
5     PRIMARY KEY (id)
6 )

這是最簡單的SQL表若是再加上外鍵什麼的,那就更加複雜了,因此就有了咱們的sqlalchemy!orm

 1 import sqlalchemy
 2 from sqlalchemy import create_engine
 3 from sqlalchemy.ext.declarative import declarative_base
 4 from sqlalchemy import Column, Integer, String
 5  
 6 engine = create_engine("mysql+pymysql://root:alex3714@localhost/testdb",
 7                                     encoding='utf-8', echo=True)
 8  
 9  
10 Base = declarative_base() #生成orm基類
11  
12 class User(Base):
13     __tablename__ = 'user' #表名
14     id = Column(Integer, primary_key=True)
15     name = Column(String(32))
16     password = Column(String(64))
17  
18 Base.metadata.create_all(engine) #建立表結構

看到這裏你可能感受不出什麼,那是由於如今實現的功能比較簡單,可是當功能複雜之後,你就會發現這個東西的好處。對象

這裏還有一種建立表的方式,可是不經常使用

 1 from sqlalchemy import Table, MetaData, Column, Integer, String, ForeignKey
 2 from sqlalchemy.orm import mapper
 3  
 4 metadata = MetaData()
 5  
 6 user = Table('user', metadata,
 7             Column('id', Integer, primary_key=True),
 8             Column('name', String(50)),
 9             Column('fullname', String(50)),
10             Column('password', String(12))
11         )
12  
13 class User(object):
14     def __init__(self, name, fullname, password):
15         self.name = name
16         self.fullname = fullname
17         self.password = password
18  
19 mapper(User, user) #the table metadata is created separately with the Table construct, then associated with the User class via the mapper() function

其實第一種就是第二種建立表方式的一種封裝

如今來建立一條數據試試

Session_class = sessionmaker(bind=engine) #建立與數據庫的會話session class ,注意,這裏返回給session的是個class,不是實例
Session = Session_class() #生成session實例
 
 
user_obj = User(name="alex",password="alex3714") #生成你要建立的數據對象
print(user_obj.name,user_obj.id)  #此時還沒建立對象呢,不信你打印一下id發現仍是None
 
Session.add(user_obj) #把要建立的數據對象添加到這個session裏, 一會統一建立
print(user_obj.name,user_obj.id) #此時也依然還沒建立
 
Session.commit() #現此才統一提交,建立數據

 

查詢:

1 my_user = Session.query(User).filter_by(name="alex").first()
2 print(my_user)

 

他輸出的是:

<__main__.User object at 0x105b4ba90>

他返回的是一個對象,因此是這個樣子,你能夠經過調出他裏面對象的方式來顯示。

1 print(my_user.id,my_user.name,my_user.password)
2  
3 輸出
4 1 alex alex3714

 不過剛纔上面的顯示的內存對象對址你是沒辦法分清返回的是什麼數據的,除非打印具體字段看一下,若是想讓它變的可讀,只需在定義表的類下面加上這樣的代碼

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

修改

1 my_user = Session.query(User).filter_by(name="alex").first()
2  
3 my_user.name = "Alex Li"
4  
5 Session.commit()

回滾

 1 my_user = Session.query(User).filter_by(id=1).first()
 2 my_user.name = "Jack"
 3  
 4  
 5 fake_user = User(name='Rain', password='12345')
 6 Session.add(fake_user)
 7  
 8 print(Session.query(User).filter(User.name.in_(['Jack','rain'])).all() )  #這時看session裏有你剛添加和修改的數據
 9  
10 Session.rollback() #此時你rollback一下
11  
12 print(Session.query(User).filter(User.name.in_(['Jack','rain'])).all() ) #再查就發現剛纔添加的數據沒有了。
13  
14 # Session
15 # Session.commit()

獲取全部數據

print(Session.query(User.name,User.id).all() )

多條件查詢

1 objs = Session.query(User).filter(User.id>0).filter(User.id<7).all()

上面2個filter的關係至關於 user.id >1 AND user.id <7 的效果

統計和分組

Session.query(User).filter(User.name.like("Ra%")).count()

分組

from sqlalchemy import func
print(Session.query(func.count(User.name),User.name).group_by(User.name).all() )

輸出爲:

[(1, 'Jack'), (2, 'Rain')]

 

外鍵關聯

建立一個address表,跟user表關聯

 1 from sqlalchemy import ForeignKey
 2 from sqlalchemy.orm import relationship
 3  
 4 class Address(Base):
 5     __tablename__ = 'addresses'
 6     id = Column(Integer, primary_key=True)
 7     email_address = Column(String(32), nullable=False)
 8     user_id = Column(Integer, ForeignKey('user.id'))
 9  
10     user = relationship("User", backref="addresses") #這個nb,容許你在user表裏經過backref字段反向查出全部它在addresses表裏的關聯項
11  
12     def __repr__(self):
13         return "<Address(email_address='%s')>" % self.email_address

表建立好之後能夠反查試試

1 obj = Session.query(User).first()
2 for i in obj.addresses: #經過user對象反查關聯的addresses記錄
3     print(i)
4  
5 addr_obj = Session.query(Address).first()
6 print(addr_obj.user.name)  #在addr_obj裏直接查關聯的user表

 

建立關聯對象

1 obj = Session.query(User).filter(User.name=='rain').all()[0]
2 print(obj.addresses)
3  
4 obj.addresses = [Address(email_address="r1@126.com"), #添加關聯對象
5                  Address(email_address="r2@126.com")]
6  
7  
8 Session.commit()
相關文章
相關標籤/搜索