亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Python數據庫的連接實現方法與注意事項

系統 1557 0

在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 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])
          

可以看出,連接數據庫大致分為以下步驟:

? (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條。


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 国产亚洲精品九九久在线观看 | 成人网在线视频 | 99久热在线精品视频播 | 国产成 人 综合 亚洲网 | 精品久久久久久久一区二区手机版 | 国内自拍在线观看 | 免费看曰批女人爽的视频网址 | jizz美女18 | 天天cao在线 | 99国产精品久久久久久久成人热 | 91精品中文字幕 | 中文字幕一区精品 | 亚洲香蕉在线观看 | 久久日韩精品中文字幕网 | 欧美日片 | 欧洲黄色网 | 波多野结衣中文字幕久久 | 中文字幕日韩女同互慰视频 | 欧美三级一区二区 | 欧美一级成人一区二区三区 | 久热这里只有精品在线 | 99在线精品免费视频九九视 | 日韩高清在线二区 | 国产精品视频九九九 | 亚洲高清不卡视频 | 国产香蕉国产精品偷在线观看 | 国产在线一区二区 | 久久久久国产精品四虎 | 奇米视频7777 | 国产欧美视频在线观看 | 一本伊大人香蕉久久网手机 | 久久国产精品吴梦梦 | 成人欧美一区二区三区视频不卡 | 性欧美高清videosex | 中文日产国产精品久久 | 变态捡到女婴h养成调教 | 狠狠久久 | 在线一区播放 | 日韩亚洲国产综合久久久 | 国产成人午夜 | 亚洲精品动漫一区二区三区在线 |