Python數(shù)據(jù)庫的連接實(shí)現(xiàn)方法與注意事項(xiàng)
在Python中要連接數(shù)據(jù)庫,首先我們得先安裝幾個(gè)重要的東西,主要有:
(1)Python-dev包
(2)setuptools-0.6c11.tar.gz
(3)MySQL-python-1.2.3.tar.gz
下面分別來說說這三個(gè)主要的包的安裝步驟:
(1)Python-dev包
直接yum install python-devel
(2)setuptools-0.6c11.tar.gz
在網(wǎng)上下載后,先解壓:tar zxf setuptools-0.6c11.tar.gz,完畢后cd到解壓后的文件夾,執(zhí)行:
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到解壓后的文件夾,執(zhí)行:
python setup.py build
python setup.py install
在執(zhí)行上述命令之前,最好先修改一個(gè)文件,我們先查找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
經(jīng)過上面的步驟,我們基本就可以MySQLdb安裝好了。
可以測(cè)試一下,在Python的交互式命令行,輸入import MySQLdb,如果沒有報(bào)錯(cuò),就說明已經(jīng)安裝好。
下面的Python代碼展示了如何連接數(shù)據(jù)庫,并執(zhí)行數(shù)據(jù)庫的一些操作:
import MySQLdb
try:
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])
可以看出,連接數(shù)據(jù)庫大致分為以下步驟:
(1)建立和數(shù)據(jù)庫系統(tǒng)的連接
(2)獲取操作游標(biāo)
(3)執(zhí)行SQL,創(chuàng)建一個(gè)數(shù)據(jù)庫(當(dāng)然這一步不是必需的,因?yàn)槲覀兛梢杂靡呀?jīng)存在的數(shù)據(jù)庫)
(4)選擇數(shù)據(jù)庫
(5)進(jìn)行各種數(shù)據(jù)庫操作
(6)操作完畢后,提交事務(wù)(這一步很重要,因?yàn)橹挥刑峤皇聞?wù)后,數(shù)據(jù)才能真正寫進(jìn)數(shù)據(jù)庫)
(7)關(guān)閉操作游標(biāo)
(8)關(guān)閉數(shù)據(jù)庫連接
當(dāng)然,如果我們使用已經(jīng)存在的數(shù)據(jù)庫,那么在獲取連接時(shí)就可以制定了,比如:
conn = MySQLdb.connect(host='localhost', user='root', passwd='root', db='PythonDB')
如果數(shù)據(jù)庫中有中文,為了防止亂碼,我們加入屬性charset = 'uft-8'或者'gb2312',charset要跟數(shù)據(jù)庫的編碼一致。
conn = MySQLdb.connect(host='localhost', user='root',
passwd='root', db='PythonDB',charset='utf8')
下面貼一下常用的函數(shù):
數(shù)據(jù)庫連接對(duì)事務(wù)操作的方法:commit() 提交 rollback() 回滾
cursor用來執(zhí)行命令的方法:
callproc(self,procname,args)
用來執(zhí)行存儲(chǔ)過程,接收的參數(shù)為存儲(chǔ)過程名和參數(shù)列表,返回值為受影響的行數(shù)
execute(self, query, args)
執(zhí)行單條sql語句,接收的參數(shù)為sql語句本身和使用的參數(shù)列表,返回值為受影響的行數(shù)
executemany(self, query, args)
執(zhí)行單挑sql語句,但是重復(fù)執(zhí)行參數(shù)列表里的參數(shù),返回值為受影響的行數(shù)
nextset(self)
移動(dòng)到下一個(gè)結(jié)果集
cursor用來接收返回值的方法:
fetchall(self)
接收全部的返回結(jié)果行
fetchmany(self, size=None)
接收size條返回結(jié)果行.如果size的值大于返回的結(jié)果行的數(shù)量,則會(huì)返回cursor.arraysize條數(shù)據(jù)
fetchone(self)
返回一條結(jié)果行
scroll(self, value, mode='relative')
移動(dòng)指針到某一行,如果mode='relative',則表示從當(dāng)前所在行移動(dòng)value條,如果 mode='absolute',則表示從結(jié)果集的第一行移動(dòng)value條。
- Python連接DB2數(shù)據(jù)庫
- Python Sql數(shù)據(jù)庫增刪改查操作簡(jiǎn)單封裝
- Python對(duì)數(shù)據(jù)庫操作
- Python簡(jiǎn)單連接MongoDB數(shù)據(jù)庫的方法
- python訪問mysql數(shù)據(jù)庫的實(shí)現(xiàn)方法(2則示例)
- Python操作MySQL數(shù)據(jù)庫9個(gè)實(shí)用實(shí)例
- linux下python3連接mysql數(shù)據(jù)庫問題
- 在Python的Django框架中更新數(shù)據(jù)庫數(shù)據(jù)的方法
- python數(shù)據(jù)庫操作常用功能使用詳解(創(chuàng)建表/插入數(shù)據(jù)/獲取數(shù)據(jù))
- python Django連接MySQL數(shù)據(jù)庫做增刪改查
- Python讀寫Redis數(shù)據(jù)庫操作示例
- python連接oracle數(shù)據(jù)庫實(shí)例
- Python操作Access數(shù)據(jù)庫基本步驟分析
相關(guān)文章
Pandas庫之DataFrame使用的學(xué)習(xí)筆記
這篇文章主要介紹了Pandas庫之DataFrame使用的學(xué)習(xí)筆記,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06
Python Web框架Flask中使用新浪SAE云存儲(chǔ)實(shí)例
這篇文章主要介紹了Python Web框架Flask中使用新浪SAE云存儲(chǔ)實(shí)例,本文是對(duì)SAE云存儲(chǔ)的簡(jiǎn)單封裝,需要的朋友可以參考下2015-02-02
Python實(shí)現(xiàn)計(jì)算函數(shù)或程序執(zhí)行時(shí)間
在Python程序的開發(fā)過程中,一些程序需要獲取函數(shù)或程序的開始時(shí)間、結(jié)束時(shí)間和時(shí)間間隔等內(nèi)容用來分析和處理內(nèi)容。本文就來聊聊具體實(shí)現(xiàn)方法2023-02-02
Django 登陸驗(yàn)證碼和中間件的實(shí)現(xiàn)
Python數(shù)據(jù)序列化技術(shù)總結(jié)

