欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python數(shù)據(jù)庫的連接實(shí)現(xiàn)方法與注意事項(xiàng)

 更新時(shí)間:2016年02月27日 22:34:13   投稿:mdxy-dxy  
這篇文章主要介紹了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條。

相關(guān)文章

  • Python多線程與多處理之間的區(qū)別詳解

    Python多線程與多處理之間的區(qū)別詳解

    在本文中,我們將學(xué)習(xí) Python 中多線程和多處理的內(nèi)容、原因和方式,文中通過代碼示例給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-01-01
  • python服務(wù)器與android客戶端socket通信實(shí)例

    python服務(wù)器與android客戶端socket通信實(shí)例

    這篇文章主要介紹了python服務(wù)器與android客戶端socket通信的實(shí)現(xiàn)方法,實(shí)例形式詳細(xì)講述了Python的服務(wù)器端實(shí)現(xiàn)原理與方法,以及對(duì)應(yīng)的Android客戶端實(shí)現(xiàn)方法,需要的朋友可以參考下
    2014-11-11
  • Python NumPy灰度圖像的壓縮原理講解

    Python NumPy灰度圖像的壓縮原理講解

    在本篇文章里小編給大家整理的是一篇關(guān)于Python NumPy灰度圖像的壓縮原理講解內(nèi)容,有興趣的朋友們可以學(xué)習(xí)參考下。
    2021-08-08
  • 教你怎么用python批量登錄帶有驗(yàn)證碼的網(wǎng)站

    教你怎么用python批量登錄帶有驗(yàn)證碼的網(wǎng)站

    這篇文章主要介紹了教你怎么用python批量登錄帶有驗(yàn)證碼的網(wǎng)站,文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)python的小伙伴們有很好的幫助,需要的朋友可以參考下
    2021-04-04
  • 使用opencv將視頻幀轉(zhuǎn)成圖片輸出

    使用opencv將視頻幀轉(zhuǎn)成圖片輸出

    今天小編就為大家分享一篇使用opencv將視頻幀轉(zhuǎn)成圖片輸出,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • python3使用matplotlib繪制條形圖

    python3使用matplotlib繪制條形圖

    這篇文章主要為大家詳細(xì)介紹了python3使用matplotlib繪制條形圖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-03-03
  • python導(dǎo)入csv文件出現(xiàn)SyntaxError問題分析

    python導(dǎo)入csv文件出現(xiàn)SyntaxError問題分析

    這篇文章主要介紹了python導(dǎo)入csv文件出現(xiàn)SyntaxError問題分析,同時(shí)涉及python導(dǎo)入csv文件的三種方法,具有一定借鑒價(jià)值,需要的朋友可以參考下。
    2017-12-12
  • 解決Python Matplotlib繪圖數(shù)據(jù)點(diǎn)位置錯(cuò)亂問題

    解決Python Matplotlib繪圖數(shù)據(jù)點(diǎn)位置錯(cuò)亂問題

    這篇文章主要介紹了解決Python Matplotlib繪圖數(shù)據(jù)點(diǎn)位置錯(cuò)亂問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05
  • Python?Pandas實(shí)現(xiàn)將字符串格式轉(zhuǎn)為日期時(shí)間格式

    Python?Pandas實(shí)現(xiàn)將字符串格式轉(zhuǎn)為日期時(shí)間格式

    日期和時(shí)間數(shù)據(jù)在數(shù)據(jù)分析和處理中起著關(guān)鍵作用,本文將詳細(xì)介紹如何使用Pandas將字符串格式的日期時(shí)間數(shù)據(jù)轉(zhuǎn)換為日期時(shí)間格式,需要的可以參考下
    2024-01-01
  • anaconda如何查看并管理python環(huán)境

    anaconda如何查看并管理python環(huán)境

    這篇文章主要介紹了anaconda如何查看并管理python環(huán)境,Anaconda是Python的一個(gè)開源發(fā)行版本,主要面向科學(xué)計(jì)算,預(yù)裝了豐富強(qiáng)大的庫。使用Anaconda可以輕松管理多個(gè)版本的Python環(huán)境,需要的朋友可以參考下
    2019-07-07

最新評(píng)論