Python的ORM架構SQLObject入門執行個體

來源:互聯網
上載者:User
SQLObject和SQLAlchemy都是Python語言下的ORM(對象關係映射)解決方案,其中SQLAlchemy被認為是Python下事實上的ORM標準。當然,兩者都很優秀。

一、安裝

代碼如下:

sudo pip install SQLObject


使用SQLObject操作mysql時候報錯ImportError: No module named MySQLdb,那便安裝MySQLdb:

代碼如下:

sudo pip install MySQL-python


沒想到又報錯了:

代碼如下:


_mysql.c:29:20: fatal error: Python.h: No such file or directory
compilation terminated.
error: command 'x86_64-linux-gnu-gcc' failed with exit status 1


解決方案:

代碼如下:


sudo apt-get install libmysqlclient-dev python-dev



二、使用其建立表

將mysql預設存在的test資料庫的編碼改為utf-8。

代碼如下:

#-*-encoding:utf-8-*-
from sqlobject import *

uri = r'mysql://root:passwd@127.0.0.1/test?charset=utf8'
sqlhub.processConnection = connectionForURI(uri)

class User(SQLObject):
name = StringCol(length=10, notNone=True)
email = StringCol(length=20, notNone=True)
password = StringCol(length=20, notNone=True)

User.createTable()

運行後,會看到test資料庫下出現表user,我們使用show create table user;查看user表的建立語句,結果如下:

代碼如下:


CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(10) NOT NULL,
`email` varchar(20) NOT NULL,
`password` varchar(20) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8

三、添加/刪除記錄

現在我們嘗試著添加和刪除記錄。

代碼如下:


user1 = User(name='user1',email='user1@163.com',password='111')
user2 = User(name='user2',email='user2@163.com',password='222')

運行後,使用select * from user能看到這兩個記錄:

代碼如下:


mysql> select * from user;
+----+-------+---------------+----------+
| id | name | email | password |
+----+-------+---------------+----------+
| 1 | user1 | user1@163.com | 111 |
| 2 | user2 | user2@163.com | 222 |
+----+-------+---------------+----------+
2 rows in set (0.00 sec)

刪除資料

代碼如下:


u2 = User.get(2)
print User.delete(u2.id)

四、查詢記錄


通過id擷取資料:

代碼如下:


u1 = User.get(1)
u1_1 = User.get(1)
u2 = User.get(2)
print id(u1), u1
print id(u1_1), u1_1
print id(u2), u2


輸出結果:

代碼如下:


23864656
23864656
23930512


由於id(u1)和id(u1_1)是相等的,所以u1和u1_1是內容一致,這樣做可以減少記憶體使用量。可以在串連資料庫時候設定參數,禁止該方式。

根據name進行查詢:

代碼如下:


users = User.select(User.q.name=="user1")
print users
print list(users)


輸出結果:

代碼如下:


SELECT user.id, user.name, user.email, user.password FROM user WHERE ((user.name) = ('user1'))
[]


模糊查詢:

代碼如下:


users = User.select(User.q.name.startswith('u'))
print users
print list(users)
users = User.select(User.q.name.contains('ser1'))
print users
print list(users)


運行結果:

代碼如下:


SELECT user.id, user.name, user.email, user.password FROM user WHERE (user.name LIKE ('u%') ESCAPE '\\')
[, ]
SELECT user.id, user.name, user.email, user.password FROM user WHERE (user.name LIKE ('%ser1%') ESCAPE '\\')
[]

一對多映射

我們建立一個表,儲存user中每個使用者的編寫的文章:

代碼如下:

class User(SQLObject):
name = StringCol(length=10, notNone=True)
email = StringCol(length=20, notNone=True)
password = StringCol(length=20, notNone=True)

class Article(SQLObject):
title = StringCol(length=100, notNone=True)
content = StringCol(notNone=True)
user = ForeignKey('User')
Article.createTable()


運行後,使用show create table article查看建立語句:

代碼如下:


CREATE TABLE `article` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`title` varchar(100) NOT NULL,
`content` text NOT NULL,
`user_id` int(11) DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `article_user_id_exists` (`user_id`),
CONSTRAINT `article_user_id_exists` FOREIGN KEY (`user_id`) REFERENCES `user` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8


添加資料:

代碼如下:


u1 = User.get(1)
a1 = Article(title='title1',content='你好',user=u1)


查詢資料:

代碼如下:


u1 = User.get(1)
a1 = Article.select(Article.q.user == u1)
print a1
print list(a1)
print list(a1)[0].content


這種方式也可以:

代碼如下:


a1 = Article.select(Article.q.userID == 1)
print a1
print list(a1)
print list(a1)[0].content


運行結果:

代碼如下:


SELECT article.id, article.title, article.content, article.user_id FROM article WHERE ((article.user_id) = (1))
[]
你好

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.