跟老齊學Python之通過Python連接數(shù)據(jù)庫
用Python來編寫網(wǎng)站,必須要能夠通過python操作數(shù)據(jù)庫,所謂操作數(shù)據(jù)庫,就是通過python實現(xiàn)對數(shù)據(jù)的連接,以及對記錄、字段的各種操作。上一講提到的那種操作方式,是看官直接通過交互模式來操作數(shù)據(jù)庫。
安裝python-MySQLdb
要想通過python來操作數(shù)據(jù)庫,還需要在已經(jīng)安裝了mysql的基礎上安裝一個稱之為mysqldb的庫,它是一個接口程序,python通過它對mysql數(shù)據(jù)實現(xiàn)各種操作。
在編程中,會遇到很多類似的接口程序,通過接口程序?qū)α硗庖粋€對象進行操作,比較簡單。接口程序就好比鑰匙,如果要開鎖,人直接用手指去捅,肯定是不行的,那么必須借助工具,插入到鎖孔中,把所打開,打開所之后,門開了,就可以操作門里面的東西了。那么打開所的工具就是接口程序。而打開所的工具會有便利與否之分,如果用這鎖的鑰匙,就便利,如果用別的工具,或許不便利(其實還分人,也就是人開鎖的水平,如果是江洋大盜或者小毛賊什么的,擅長開鎖,用別的工具也便利了),也就是接口程序不同,編碼水平不同,都是考慮因素。
這里下載python-mysqldb:https://pypi.python.org/pypi/MySQL-python/
下載之后就可以安裝了。
我這里只能演示ubuntu下安裝的過程。
sudo apt-get install python-MySQLdb
在shell中輸入上面的命令行,就安裝了??纯矗嗝春啙嵉陌惭b,請快快用ubuntu吧。我愿意做ubuntu的免費代言。哈哈。
不管什么系統(tǒng),安裝不是難題。安裝之后,怎么知道安裝的結果呢?
>>> import MySQLdb
在python的交互模式中,輸入上面的指令,如果不報錯,恭喜你,已經(jīng)安裝好了。如果報錯,恭喜你,可以借著錯誤信息提高自己的計算機水平了,請求助于google大神。
交互模式下操作數(shù)據(jù)庫之連接數(shù)據(jù)庫
操作數(shù)據(jù)庫的前提是先有數(shù)據(jù)庫。
先建立一個數(shù)據(jù)庫。
打開數(shù)據(jù)庫,正確輸入密碼之后,呈現(xiàn)下面的結果
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 373
Server version: 5.5.38-0ubuntu0.14.04.1 (Ubuntu)
Copyright (c) 2000, 2014, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql>
在這個狀態(tài)下,輸入如下命令,建立一個數(shù)據(jù)庫:
mysql> create database qiwsirtest character set utf8;
Query OK, 1 row affected (0.00 sec)
注意上面的指令,如果僅僅輸入:create database qiwsirtest,也可以,但是,我在后面增加了character set utf8,意思是所建立的數(shù)據(jù)庫qiwsirtest,編碼是utf-8的,這樣存入漢字就不是亂碼了。
看到那一行提示:Query OK, 1 row affected (0.00 sec),就說明這個數(shù)據(jù)庫已經(jīng)建立好了,名字叫做:qiwsirtest
數(shù)據(jù)庫建立之后,就可以用python通過已經(jīng)安裝的mysqldb來連接這個名字叫做qiwsirtest的庫了。進入到python交互模式(現(xiàn)在這個實驗室做實驗)。
>>> import MySQLdb
>>> conn = MySQLdb.connect(host="localhost",user="root",passwd="123123",db="qiwsirtest",port=3306,charset="utf8")
逐個解釋上述命令的含義:
host:等號的后面應該填寫mysql數(shù)據(jù)庫的地址,因為就數(shù)據(jù)庫就在本機上(也稱作本地),所以使用localhost,注意引號。如果在其它的服務器上,這里應該填寫ip地址。一般中小型的網(wǎng)站,數(shù)據(jù)庫和程序都是在同一臺服務器(計算機)上,就使用localhost了。
user:登錄數(shù)據(jù)庫的用戶名,這里一般填寫"root",還是要注意引號。當然,如果是比較大型的服務,數(shù)據(jù)庫會提供不同的用戶,那時候可以更改為相應用戶。但是,不同用戶的權限可能不同,所以,在程序中,如果要操作數(shù)據(jù)庫,還要注意所擁有的權限。在這里用root,就放心了,什么權限都有啦。不過,這樣做,在大型系統(tǒng)中是應該避免的。
passwd:上述user賬戶對應的登錄mysql的密碼。我在上面的例子中用的密碼是"123123"。不要忘記引號。
db:就是剛剛通create命令建立的數(shù)據(jù)庫,我建立的數(shù)據(jù)庫名字是"qiwsirtest",還是要注意引號。看官如果建立的數(shù)據(jù)庫名字不是這個,就寫自己所建數(shù)據(jù)庫名字。
port:一般情況,mysql的默認端口是3306,當mysql被安裝到服務器之后,為了能夠允許網(wǎng)絡訪問,服務器(計算機)要提供一個訪問端口給它。
charset:這個設置,在很多教程中都不寫,結果在真正進行數(shù)據(jù)存儲的時候,發(fā)現(xiàn)有亂碼。這里我將qiwsirtest這個數(shù)據(jù)庫的編碼設置為utf-8格式,這樣就允許存入漢字而無亂碼了。注意,在mysql設置中,utf-8寫成utf8,沒有中間的橫線。但是在python文件開頭和其它地方設置編碼格式的時候,要寫成utf-8。切記!
注:connect中的host、user、passwd等可以不寫,只有在寫的時候按照host、user、passwd、db(可以不寫)、port順序?qū)懢涂梢?,注意端口號port=3306還是不要省略的為好,如果沒有db在port前面,直接寫3306會報錯.
其實,關于connect的參數(shù)還不少,下面摘抄來自mysqldb官方文檔的內(nèi)容,把所有的參數(shù)都列出來,還有相關說明,請看官認真閱讀。不過,上面幾個是常用的,其它的看情況使用。
- python使用mysqldb連接數(shù)據(jù)庫操作方法示例詳解
- python連接數(shù)據(jù)庫的方法
- Python連接數(shù)據(jù)庫學習之DB-API詳解
- python mysqldb連接數(shù)據(jù)庫
- Python使用sqlalchemy模塊連接數(shù)據(jù)庫操作示例
- 學習python之編寫簡單簡單連接數(shù)據(jù)庫并執(zhí)行查詢操作
- Python 3.x 連接數(shù)據(jù)庫示例(pymysql 方式)
- Python使用Flask-SQLAlchemy連接數(shù)據(jù)庫操作示例
- 解決python3 Pycharm上連接數(shù)據(jù)庫時報錯的問題
- Python與數(shù)據(jù)庫交互:入門指南
相關文章
Python實現(xiàn)的連接mssql數(shù)據(jù)庫操作示例
這篇文章主要介紹了Python實現(xiàn)的連接mssql數(shù)據(jù)庫操作,結合實例形式分析了Python安裝pymssql模塊以及基于pymssql模塊連接sql2008 R2數(shù)據(jù)庫的具體操作技巧,需要的朋友可以參考下2018-08-08Python獲取CPU、內(nèi)存使用率以及網(wǎng)絡使用狀態(tài)代碼
這篇文章主要介紹了Python獲取CPU使用率、內(nèi)存使用率、網(wǎng)絡使用狀態(tài)的相關代碼,對此有需要的朋友一起測試下。2018-02-02django中url映射規(guī)則和服務端響應順序的實現(xiàn)
這篇文章主要介紹了django中url映射規(guī)則和服務端響應順序的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-04-04手把手教你用Matplotlib實現(xiàn)數(shù)據(jù)可視化
Matplotlib是支持?Python語言的開源繪圖庫,因為其支持豐富的繪圖類型、簡單的繪圖方式以及完善的接口文檔,深受?Python?工程師、科研學者、數(shù)據(jù)工程師等各類人士的喜歡。本文將詳細為大家介紹如何用Matplotlib實現(xiàn)數(shù)據(jù)可視化,需要的可以參考一下2022-02-02