Python資料庫的串連實現方法與注意事項

來源:互聯網
上載者:User
在Python中要串連資料庫,首先我們得先安裝幾個重要的東西,主要有:

(1)Python-dev包
(2)setuptools-0.6c11.tar.gz
(3)MySQL-python-1.2.3.tar.gz

下面分別來說說這三個主要的包的安裝步驟:

(1)Python-dev包
直接yum install python-devel

(2)setuptools-0.6c11.tar.gz
在網上下載後,先解壓:tar zxf setuptools-0.6c11.tar.gz,完畢後cd到解壓後的檔案夾,執行:
python setup.py build
python setup.py install

(3)MySQL-python-1.2.3.tar.gz
跟安裝setuptools-0.6c11.tar.gz步驟一樣,先解壓:tar zxfMySQL-python-1.2.3.tar.gz,
完畢後cd到解壓後的檔案夾,執行:

python setup.py build
python setup.py install

在執行上述命令之前,最好先修改一個檔案,我們先尋找mysql_config的位置,使用命令:
find / -name mysql_config
然後我們擷取到它的路徑,我的是:/usr/bin/mysql_config,然後修改MySQL-python-1.2.3目錄下
的site.cfg檔案,去掉mysql_config=XXX這行前面的#,改為:
mysql_config = /usr/bin/mysql_config

經過上面的步驟,我們基本就可以MySQLdb安裝好了。

可以測試一下,在Python的互動式命令列,輸入import MySQLdb,如果沒有報錯,就說明已經安裝好。

下面的Python代碼展示了如何串連資料庫,並執行資料庫的一些操作:

import MySQLdbtry:  conn = MySQLdb.connect(host='localhost',user='root',passwd='root',port=3306)  cur = conn.cursor()  cur.execute('create database if not exists PythonDB')  conn.select_db('PythonDB')  cur.execute('create table Test(id int,name varchar(20),info varchar(20))')  value = [1,'ACdreamer','student']  cur.execute('insert into Test values(%s,%s,%s)',value)  values = []  for i in range(20):    values.append((i,'Hello World!','My number is '+str(i)))  cur.executemany('insert into Test values(%s,%s,%s)',values)  cur.execute('update Test set name="ACdreamer" where id=3')  conn.commit()  cur.close()  conn.close()except MySQLdb.Error,msg:  print "MySQL Error %d: %s" %(msg.args[0],msg.args[1])

可以看出,串連資料庫大致分為以下步驟:

(1)建立和資料庫系統的串連
(2)擷取操作遊標
(3)執行SQL,建立一個資料庫(當然這一步不是必需的,因為我們可以用已經存在的資料庫)
(4)選擇資料庫
(5)進行各種資料庫操作
(6)操作完畢後,提交事務(這一步很重要,因為只有提交事務後,資料才能真正寫進資料庫)
(7)關閉操作遊標
(8)關閉資料庫連接

當然,如果我們使用已經存在的資料庫,那麼在擷取串連時就可以制定了,比如:
conn = MySQLdb.connect(host='localhost', user='root', passwd='root', db='PythonDB')

如果資料庫中有中文,為了防止亂碼,我們加入屬性charset = 'uft-8'或者'gb2312',charset要跟資料庫的編碼一致。
conn = MySQLdb.connect(host='localhost', user='root',
passwd='root', db='PythonDB',charset='utf8')

下面貼一下常用的函數:

資料庫連接對事務操作的方法:commit() 提交 rollback() 復原

cursor用來執行命令的方法:

callproc(self,procname,args)
用來執行預存程序,接收的參數為預存程序名和參數列表,傳回值為受影響的行數

execute(self, query, args)
執行單條sql語句,接收的參數為sql語句本身和使用的參數列表,傳回值為受影響的行數

executemany(self, query, args)
執行單挑sql語句,但是重複執行參數列表裡的參數,傳回值為受影響的行數

nextset(self)
移動到下一個結果集

cursor用來接收傳回值的方法:

fetchall(self)
接收全部的返回結果行

fetchmany(self, size=None)
接收size條返回結果行.如果size的值大於返回的結果行的數量,則會返回cursor.arraysize條資料

fetchone(self)
返回一條結果行

scroll(self, value, mode='relative')
移動指標到某一行,如果mode='relative',則表示從當前所在行移動value條,如果 mode='absolute',則表示從結果集的第一行移動value條。

  • 聯繫我們

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