MySQL---連接器(python如何操作資料庫媒介,基於python語言)

來源:互聯網
上載者:User

標籤:property   val   成功   傳回值   from   isis   cat   資料類型   tca   

MySQL — 連接器連接器的概念

它們往往是一類Python,或者是一類已經寫好的Python庫。這些庫提供了我們Python去串連資料庫伺服器的準系統。

? 既然它是一個包,那麼我們首先學會匯入這個包

#! /usr/bin/env python3
# coding: utf-8
?
from mysql import connector
print(‘匯入成功‘)

執行以上代碼

$ python3 test_connector.py
匯入成功

表示我們成功匯入了相關的包或者模組

連接器文法

要學習連接器文法,我們可以參考:https://dev.mysql.com/doc/connector-python/en/

串連

串連有兩個部分,不可或缺:

  • 串連資訊: 主機連接埠使用者名稱密碼資料庫名

    db_config = {
        ‘host‘: ‘localhost‘,#主機
        ‘port‘: 3306,#連接埠
        ‘user‘: ‘???‘,#使用者
        ‘passwd‘: ‘???‘,#密碼
        ‘db‘: ‘python‘,#串連的資料庫
    }
  • 串連函數:所有連接器都有的函數,名字叫connect

     
    from mysql.connector import connect

    注意:該函數反回的是一個代表著串連的對象,我們可以把這個連線物件看成是用戶端。

遊標

遊標是從一個特定的串連中擷取的,cnn中有一個cursor方法,可以返回一個遊標對象。

cur = cnn.cursor()

操作資料庫都是通過遊標來進行,一個串連可以產生多個遊標。

遊標,其中有一個execute方法,只需要把我們需要執行的SQL語句當作參數傳入其中,就可以讓連接器指揮MySQL伺服器執行語句。

注意execute並沒有傳回值

那麼,查處來的星系在哪呢?

其實,查出來的資訊就在我們的遊標中。

由於,我們查出來的資料都是以行的形式出現的(查出來的是一條條記錄),全部存在遊標裡,當我們迭代這個遊標的時候,我們其實是依次的拿到了其中的行(記錄),每次輸出我們的迭代項的時候,我們就是輸出了其中的一行。

#! /usr/bin/env python3
# coding: utf-8
?
from mysql.connector import connect
?
db_config = {
    ‘host‘: ‘localhost‘,
    ‘port‘: 3306,
    ‘user‘: ‘???‘,
    ‘passwd‘: ‘???‘,
    ‘db‘: ‘mysql‘,  # 相當於自動USE
}
?
cnn = connect(**db_config)
cur = cnn.cursor()
print(cur.execute(‘SELECT Host, User, authentication_string FROM user‘))
?
for i in cur:
    print(i)

執行上面的代碼

[email protected]:~/testgit/learning_connector$ python3 test_cursor.py
None
(bytearray(b‘localhost‘), bytearray(b‘root‘), b‘*81BCF9486900824FB0A3746219755FC21C50D058‘)
(bytearray(b‘localhost‘), bytearray(b‘mysql.sys‘), b‘*THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE‘)
(bytearray(b‘localhost‘), bytearray(b‘debian-sys-maint‘), b‘*599D0C45E62D3A9D58D74C0C5008688F13738AE5‘)
(bytearray(b‘%‘), bytearray(b‘tuple‘), b‘*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9‘)

連接器,會自動幫我們,在Python的資料類型,和Mysql資料類型中自動轉換。

關閉

使用連接器,和使用檔案一樣,一定要記得關閉,順序是

  1. 先關遊標
  2. 再關串連
 
#! /usr/bin/env python3
# coding: utf-8
?
from mysql.connector import connect
?
db_config = {
    ‘host‘: ‘localhost‘,
    ‘port‘: 3306,
    ‘user‘: ‘???‘,
    ‘passwd‘: ‘???‘,
    ‘db‘: ‘python‘,  # 相當於自動USE
}
?
cnn = connect(**db_config)
cur = cnn.cursor()
?
sql_1 = ‘‘‘
CREATE TABLE `from_connector` (
  `id` int PRIMARY KEY auto_increment,
  `name` varchar(20) NOT NULL
)
‘‘‘
?
sql_2 = ‘‘‘
SHOW TABLES
‘‘‘
?
cur.execute(sql_1)
cur.execute(sql_2)
for i in cur:
    print(i)
    
cur.close()
cnn.close()

ps:具有更好的東西,希望能夠跟大家多多交流學習;

MySQL---連接器(python如何操作資料庫媒介,基於python語言)

相關文章

聯繫我們

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