跳到主要內容


Python-資料庫-mysql-sqlalchemy

Python
資料庫
mysql-sqlalchemy

安裝
Linux、mac : pip3 install SQLAlchemy
windows     :之後補充

第一部分
from sqlalchemy import create_engine
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker

engine = create_engine('sqlite:///:memory', echo=False)
Base = declarative_base()
Session = sessionmaker(bind=engine)


第二部分
from test_sqlalchemy import *
from sqlalchemy import Column, Integer, String

class User(Base):
__tablename__ = 'users'
id = Column(Integer, primary_key=True)
name = Column(String)
fullname = Column(String)
password = Column(String)

def __repr(self):
return "<User(name={})>".format(self.name)


第三部分
from test_sqlalchemy import *
from build_model import *

Base.metadata.create_all(engine)
user1 = User(name='user1', fullname='user1', password='user1')
user2 = User(name='user2', fullname='user2', password='user2')
user3 = User(name='user3', fullname='user3', password='user3')

# Insert Data
session = Session()
session.add(user1)
session.add(user2)
session.add(user3)
session.commit()
print('------------------')
# Search Data
for name,fullname in session.query(User.name,User.fullname):
print(name, fullname)
print('------------------')
# Modify Data
user1.fullname = 'user1 fullname version'
session.commit()
for name,fullname in session.query(User.name,User.fullname):
print(name, fullname)
print('------------------')
# Delete Data
session.delete(user1)
session.delete(user2)
session.delete(user3)
session.commit()
for name,fullname in session.query(User.name,User.fullname):
print(name, fullname)

print('------------------')


session.close()

程式碼說明

第一部分:定義engine,這邊使用sqlite,定義base模型,定義session
第二部分:定義model類別,繼承自base
第三部分:
執行階段,建立資料庫,建立使用者資料,加入session,並執行,
搜尋資料
修正資料,並執行
刪除資料,並執行,顯示刪除後資料庫

留言

這個網誌中的熱門文章

程式語言學習概論(1)

程式語言 介紹

Python-設計模式-共享模式

Python 設計模式 共享模式 class Font:     def __init__(self):        self.Size = 0        self.Type = ''     def printAll(self):        print(self.Size, self.Type)  class FontFacotry:     def Word(self, Size=3, Type='1'):        F = Font()        F.Size = Size        F.Type = Type        return F  FontSize = [1,2,3] FontType = ['1','2','3'] Facotry = FontFacotry()  F1 = Facotry.Word(FontSize[0],FontType[0])  F1.printAll()  F2 = Facotry.Word( FontSize[1],FontType[1] ) F2.printAll()  F3 = Facotry.Word( FontSize[2],FontType[2] ) F3.printAll() 程式碼說明 font 定義類別 fontFacotry物件生成工廠 fontsize用來儲存font大小的外部空間 fonttype用來儲存font種類的外部空間

Python-資料庫

Python 資料庫 基本概念說明 參考程式語言概念- 資料庫內容 。 對於這邊的介紹其實,主要是對基本語法、資料庫的基本操作進行說明,所以大多只會看到語法指令,而不會深究內容,因為其內容會在SQL跟noSQL的文章內容進行說明,這邊說明會讓篇幅太多。 常見的資料庫 SQL:MySQL NoSQL:Mongodb 以下是處理該類型檔案對應函式或模組 資料庫名稱 模組 MySql MySQLdb mysqlclient PyMySQL mysql.connector peewee SQLAlchemy Mongodb pymongo PyMySQL 用python全實作的model,需要下SQL語法。 範例- 連結 SQLAlchemy 用ORM的概念做出來,支援各種SQL資料庫。 範例- 連結 pymongo 專門用來連結mongodb的module 範例- 連結