老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

重慶分公司,新征程啟航

為企業(yè)提供網(wǎng)站建設、域名注冊、服務器等服務

包含python怎么連接mysql數(shù)據(jù)庫的詞條

掌握Python 操作 MySQL 數(shù)據(jù)庫

本文Python 操作 MySQL 數(shù)據(jù)庫需要是使用到 PyMySQL 驅(qū)動

創(chuàng)新互聯(lián)公司堅持“要么做到,要么別承諾”的工作理念,服務領域包括:成都做網(wǎng)站、成都網(wǎng)站制作、成都外貿(mào)網(wǎng)站建設、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務,滿足客戶于互聯(lián)網(wǎng)時代的吉陽網(wǎng)站設計、移動媒體設計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡建設合作伙伴!

Python 操作 MySQL 前提是要安裝好 MySQL 數(shù)據(jù)庫并能正常連接使用,安裝步驟詳見下文。

注意: 安裝過程我們需要通過開啟管理員權(quán)限來安裝,否則會由于權(quán)限不足導致無法安裝。

首先需要先下載 MySQL 安裝包, 官網(wǎng)下載地址 下載對應版本即可,或直接在網(wǎng)上拉取并安裝:

權(quán)限設置:

初始化 MySQL:

啟動 MySQL:

查看 MySQL 運行狀態(tài):

Mysql安裝成功后,默認的root用戶密碼為空,你可以使用以下命令來創(chuàng)建root用戶的密碼:

登陸:

創(chuàng)建數(shù)據(jù)庫:

查看數(shù)據(jù)庫:

PyMySQL 模塊使用 pip命令進行安裝:

假如系統(tǒng)不支持 pip 命令,可以使用以下方式安裝:

pymysql .connect 函數(shù):連接上數(shù)據(jù)庫

輸出結(jié)果顯示如下:表面數(shù)據(jù)庫連接成功

使用 pymysql 的 connect() 方法連接數(shù)據(jù)庫,connect 參數(shù)解釋如下:

conn.cursor():獲取游標

如果要操作數(shù)據(jù)庫,光連接數(shù)據(jù)是不夠的,咱們必須拿到操作數(shù)據(jù)庫的游標,才能進行后續(xù)的操作,游標的主要作用是用來接收數(shù)據(jù)庫操作后的返回結(jié)果,比如讀取數(shù)據(jù)、添加數(shù)據(jù)。通過獲取到的數(shù)據(jù)庫連接實例 conn 下的 cursor() 方法來創(chuàng)建游標,實例如下:

輸出結(jié)果為:

cursor 返回一個游標實例對象,其中包含了很多操作數(shù)據(jù)的方法,如執(zhí)行sql語句,sql 執(zhí)行命令: execute() 和 executemany()

execute(query,args=None):

executemany(query,args=None):

其他游標對象如下表:

完整數(shù)據(jù)庫連接操作實例如下:

以上結(jié)果輸出為:

創(chuàng)建表代碼如下:

如下所示數(shù)據(jù)庫表創(chuàng)建成功:

插入數(shù)據(jù)實現(xiàn)代碼:

插入數(shù)據(jù)結(jié)果:

Python查詢Mysql使用 fetchone() 方法獲取單條數(shù)據(jù), 使用fetchall() 方法獲取多條數(shù)據(jù)。

查詢數(shù)據(jù)代碼如下:

輸出結(jié)果:

DB API中定義了一些數(shù)據(jù)庫操作的錯誤及異常,下表列出了這些錯誤和異常:

本文給大家介紹 Python 如何連接 Mysql 進行數(shù)據(jù)的增刪改查操作,文章通過簡潔的代碼方式進行示例演示,給使用 Python 操作 Mysql 的工程師提供支撐。

怎么用python連接mysql數(shù)據(jù)庫

在 Python 語言環(huán)境下我們這樣連接數(shù)據(jù)庫。

In [1]: from mysql import connector

In [2]: cnx = connector.connect(host="172.16.192.100",port=3306,user="appuser",password="xxxxxx")

但是連接數(shù)據(jù)庫的背后發(fā)生了什么呢?

答案

當我們通過驅(qū)動程序(mysql-connector-python,pymysql)連接 MySQL 服務端的時候,就是把連接參數(shù)傳遞給驅(qū)動程序,驅(qū)動程序再根據(jù)參數(shù)會發(fā)起到 MySQL 服務端的 TCP 連接。當 TCP 連接建立之后驅(qū)動程序與服務端之間會按特定的格式和次序交換數(shù)據(jù)包,數(shù)據(jù)包的格式和發(fā)送次序由?MySQL 協(xié)議?規(guī)定。MySQL 協(xié)議:整個連接的過程中 MySQL 服務端與驅(qū)動程序之間,按如下的次序發(fā)送了這些包。

MySQL 服務端向客戶端發(fā)送一個握手包,包里記錄了 MySQL-Server 的版本,默認的授權(quán)插件,密碼鹽值(auth-data)。

2. MySQL 客戶端發(fā)出 ssl 連接請求包(如果有必要的話)。

3. MySQL 客戶端發(fā)出握手包的響應包,這個包時記錄了用戶名,密碼加密后的串,客戶端屬性,等等其它信息。

4. MySQL 服務端發(fā)出響應包,這個包里記錄了登錄是否成功,如果沒有成功也會給出錯誤信息。

如何用python連接mysql數(shù)據(jù)庫

數(shù)據(jù)庫連接

連接數(shù)據(jù)庫前,請先確認以下事項:

您已經(jīng)創(chuàng)建了數(shù)據(jù)庫 TESTDB.

在TESTDB數(shù)據(jù)庫中您已經(jīng)創(chuàng)建了表 EMPLOYEE

EMPLOYEE表字段為 FIRST_NAME, LAST_NAME, AGE, SEX 和 INCOME。

連接數(shù)據(jù)庫TESTDB使用的用戶名為 "testuser" ,密碼為 "test123",你可以可以自己設定或者直接使用root用戶名及其密碼,Mysql數(shù)據(jù)庫用戶授權(quán)請使用Grant命令。

在你的機子上已經(jīng)安裝了 Python MySQLdb 模塊。

如果您對sql語句不熟悉,可以訪問我們的 SQL基礎教程

python怎么連接mysql數(shù)據(jù)庫

你可以訪問Python數(shù)據(jù)庫接口及API查看詳細的支持數(shù)據(jù)庫列表。不同的數(shù)據(jù)庫你需要下載不同的DB API模塊,例如你需要訪問Oracle數(shù)據(jù)庫和Mysql數(shù)據(jù),你需要下載Oracle和MySQL數(shù)據(jù)庫模塊。

DB-API 是一個規(guī)范. 它定義了一系列必須的對象和數(shù)據(jù)庫存取方式, 以便為各種各樣的底層數(shù)據(jù)庫系統(tǒng)和多種多樣的數(shù)據(jù)庫接口程序提供一致的訪問接口 。

Python的DB-API,為大多數(shù)的數(shù)據(jù)庫實現(xiàn)了接口,使用它連接各數(shù)據(jù)庫后,就可以用相同的方式操作各數(shù)據(jù)庫。

Python DB-API使用流程:

引入 API 模塊。

獲取與數(shù)據(jù)庫的連接。

執(zhí)行SQL語句和存儲過程。

關(guān)閉數(shù)據(jù)庫連接。

什么是MySQLdb?

MySQLdb 是用于Python鏈接Mysql數(shù)據(jù)庫的接口,它實現(xiàn)了 Python 數(shù)據(jù)庫 API 規(guī)范 V2.0,基于 MySQL C API 上建立的。

如何安裝MySQLdb?

為了用DB-API編寫MySQL腳本,必須確保已經(jīng)安裝了MySQL。復制以下代碼,并執(zhí)行:

#!/usr/bin/python

# -*- coding: UTF-8 -*-

import MySQLdb

如果執(zhí)行后的輸出結(jié)果如下所示,意味著你沒有安裝 MySQLdb 模塊:

Traceback (most recent call last):

File "test.py", line 3, in module

import MySQLdb

ImportError: No module named MySQLdb

安裝MySQLdb,請訪問 ,(Linux平臺可以訪問:)從這里可選擇適合您的平臺的安裝包,分為預編譯的二進制文件和源代碼安裝包。

如果您選擇二進制文件發(fā)行版本的話,安裝過程基本安裝提示即可完成。如果從源代碼進行安裝的話,則需要切換到MySQLdb發(fā)行版本的頂級目錄,并鍵入下列命令:

$ gunzip MySQL-python-1.2.2.tar.gz

$ tar -xvf MySQL-python-1.2.2.tar

$ cd MySQL-python-1.2.2

$ python setup.py build

$ python setup.py install

注意:請確保您有root權(quán)限來安裝上述模塊。

數(shù)據(jù)庫連接

連接數(shù)據(jù)庫前,請先確認以下事項:

您已經(jīng)創(chuàng)建了數(shù)據(jù)庫 TESTDB.

在TESTDB數(shù)據(jù)庫中您已經(jīng)創(chuàng)建了表 EMPLOYEE

EMPLOYEE表字段為 FIRST_NAME, LAST_NAME, AGE, SEX 和 INCOME。

連接數(shù)據(jù)庫TESTDB使用的用戶名為 "testuser" ,密碼為 "test123",你可以可以自己設定或者直接使用root用戶名及其密碼,Mysql數(shù)據(jù)庫用戶授權(quán)請使用Grant命令。

在你的機子上已經(jīng)安裝了 Python MySQLdb 模塊。

如果您對sql語句不熟悉,可以訪問我們的 SQL基礎教程

實例:

以下實例鏈接Mysql的TESTDB數(shù)據(jù)庫:

#!/usr/bin/python

# -*- coding: UTF-8 -*-

import MySQLdb

# 打開數(shù)據(jù)庫連接

db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )

# 使用cursor()方法獲取操作游標

cursor = db.cursor()

# 使用execute方法執(zhí)行SQL語句

cursor.execute("SELECT VERSION()")

# 使用 fetchone() 方法獲取一條數(shù)據(jù)庫。

data = cursor.fetchone()

print "Database version : %s " % data

# 關(guān)閉數(shù)據(jù)庫連接

db.close()

執(zhí)行以上腳本輸出結(jié)果如下:

Database version : 5.0.45

創(chuàng)建數(shù)據(jù)庫表

如果數(shù)據(jù)庫連接存在我們可以使用execute()方法來為數(shù)據(jù)庫創(chuàng)建表,如下所示創(chuàng)建表EMPLOYEE:

#!/usr/bin/python

# -*- coding: UTF-8 -*-

import MySQLdb

# 打開數(shù)據(jù)庫連接

db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )

# 使用cursor()方法獲取操作游標

cursor = db.cursor()

# 如果數(shù)據(jù)表已經(jīng)存在使用 execute() 方法刪除表。

cursor.execute("DROP TABLE IF EXISTS EMPLOYEE")

# 創(chuàng)建數(shù)據(jù)表SQL語句

sql = """CREATE TABLE EMPLOYEE (

FIRST_NAME CHAR(20) NOT NULL,

LAST_NAME CHAR(20),

AGE INT,

SEX CHAR(1),

INCOME FLOAT )"""

cursor.execute(sql)

# 關(guān)閉數(shù)據(jù)庫連接

db.close()

數(shù)據(jù)庫插入操作

以下實例使用執(zhí)行 SQL INSERT 語句向表 EMPLOYEE 插入記錄:

#!/usr/bin/python

# -*- coding: UTF-8 -*-

import MySQLdb

# 打開數(shù)據(jù)庫連接

db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )

# 使用cursor()方法獲取操作游標

cursor = db.cursor()

# SQL 插入語句

sql = """INSERT INTO EMPLOYEE(FIRST_NAME,

LAST_NAME, AGE, SEX, INCOME)

VALUES ('Mac', 'Mohan', 20, 'M', 2000)"""

try:

# 執(zhí)行sql語句

cursor.execute(sql)

# 提交到數(shù)據(jù)庫執(zhí)行

db.commit()

except:

# Rollback in case there is any error

db.rollback()

# 關(guān)閉數(shù)據(jù)庫連接

db.close()

以上例子也可以寫成如下形式:

#!/usr/bin/python

# -*- coding: UTF-8 -*-

import MySQLdb

# 打開數(shù)據(jù)庫連接

db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )

# 使用cursor()方法獲取操作游標

cursor = db.cursor()

# SQL 插入語句

sql = "INSERT INTO EMPLOYEE(FIRST_NAME, \

LAST_NAME, AGE, SEX, INCOME) \

VALUES ('%s', '%s', '%d', '%c', '%d' )" % \

('Mac', 'Mohan', 20, 'M', 2000)

try:

# 執(zhí)行sql語句

cursor.execute(sql)

# 提交到數(shù)據(jù)庫執(zhí)行

db.commit()

except:

# 發(fā)生錯誤時回滾

db.rollback()

# 關(guān)閉數(shù)據(jù)庫連接

db.close()

實例:

以下代碼使用變量向SQL語句中傳遞參數(shù):

..................................

user_id = "test123"

password = "password"

con.execute('insert into Login values("%s", "%s")' % \

(user_id, password))

..................................

數(shù)據(jù)庫查詢操作

Python查詢Mysql使用 fetchone() 方法獲取單條數(shù)據(jù), 使用fetchall() 方法獲取多條數(shù)據(jù)。

fetchone(): 該方法獲取下一個查詢結(jié)果集。結(jié)果集是一個對象

fetchall():接收全部的返回結(jié)果行.

rowcount: 這是一個只讀屬性,并返回執(zhí)行execute()方法后影響的行數(shù)。

實例:

查詢EMPLOYEE表中salary(工資)字段大于1000的所有數(shù)據(jù):

#!/usr/bin/python

# -*- coding: UTF-8 -*-

import MySQLdb

# 打開數(shù)據(jù)庫連接

db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )

# 使用cursor()方法獲取操作游標

cursor = db.cursor()

# SQL 查詢語句

sql = "SELECT * FROM EMPLOYEE \

WHERE INCOME '%d'" % (1000)

try:

# 執(zhí)行SQL語句

cursor.execute(sql)

# 獲取所有記錄列表

results = cursor.fetchall()

for row in results:

fname = row[0]

lname = row[1]

age = row[2]

sex = row[3]

income = row[4]

# 打印結(jié)果

print "fname=%s,lname=%s,age=%d,sex=%s,income=%d" % \

(fname, lname, age, sex, income )

except:

print "Error: unable to fecth data"

# 關(guān)閉數(shù)據(jù)庫連接

db.close()

以上腳本執(zhí)行結(jié)果如下:

fname=Mac, lname=Mohan, age=20, sex=M, income=2000

數(shù)據(jù)庫更新操作

更新操作用于更新數(shù)據(jù)表的的數(shù)據(jù),以下實例將 TESTDB表中的 SEX 字段全部修改為 'M',AGE 字段遞增1:

#!/usr/bin/python

# -*- coding: UTF-8 -*-

import MySQLdb

# 打開數(shù)據(jù)庫連接

db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )

# 使用cursor()方法獲取操作游標

cursor = db.cursor()

# SQL 更新語句

sql = "UPDATE EMPLOYEE SET AGE = AGE + 1

WHERE SEX = '%c'" % ('M')

try:

# 執(zhí)行SQL語句

cursor.execute(sql)

# 提交到數(shù)據(jù)庫執(zhí)行

db.commit()

except:

# 發(fā)生錯誤時回滾

db.rollback()

# 關(guān)閉數(shù)據(jù)庫連接

db.close()

刪除操作

刪除操作用于刪除數(shù)據(jù)表中的數(shù)據(jù),以下實例演示了刪除數(shù)據(jù)表 EMPLOYEE 中 AGE 大于 20 的所有數(shù)據(jù):

#!/usr/bin/python

# -*- coding: UTF-8 -*-

import MySQLdb

# 打開數(shù)據(jù)庫連接

db = MySQLdb.connect("localhost","testuser","test123","TESTDB" )

# 使用cursor()方法獲取操作游標

cursor = db.cursor()

# SQL 刪除語句

sql = "DELETE FROM EMPLOYEE WHERE AGE '%d'" % (20)

try:

# 執(zhí)行SQL語句

cursor.execute(sql)

# 提交修改

db.commit()

except:

# 發(fā)生錯誤時回滾

db.rollback()

# 關(guān)閉連接

db.close()

執(zhí)行事務

事務機制可以確保數(shù)據(jù)一致性。

事務應該具有4個屬性:原子性、一致性、隔離性、持久性。這四個屬性通常稱為ACID特性。

原子性(atomicity)。一個事務是一個不可分割的工作單位,事務中包括的諸操作要么都做,要么都不做。

一致性(consistency)。事務必須是使數(shù)據(jù)庫從一個一致性狀態(tài)變到另一個一致性狀態(tài)。一致性與原子性是密切相關(guān)的。

隔離性(isolation)。一個事務的執(zhí)行不能被其他事務干擾。即一個事務內(nèi)部的操作及使用的數(shù)據(jù)對并發(fā)的其他事務是隔離的,并發(fā)執(zhí)行的各個事務之間不能互相干擾。

持久性(durability)。持續(xù)性也稱永久性(permanence),指一個事務一旦提交,它對數(shù)據(jù)庫中數(shù)據(jù)的改變就應該是永久性的。接下來的其他操作或故障不應該對其有任何影響。

Python DB API 2.0 的事務提供了兩個方法 commit 或 rollback。


分享題目:包含python怎么連接mysql數(shù)據(jù)庫的詞條
本文地址:http://www.xueling.net.cn/article/phpjoj.html

其他資訊

在線咨詢
服務熱線
服務熱線:028-86922220
TOP
主站蜘蛛池模板: 在线精品高清中文字幕 | 99国产网站| 网友自拍区视频精品 | 日本韩国黄色一区二区三区 | 77777亚洲午夜久久多喷 | 精品国产乱码久久久久久绯色 | 四虎黄色影院 | 337p粉嫩日本欧洲亚福利 | 久久精品亚 | 午夜福利看757 | 宅男深夜国产 | 国产99久久一区二区三区 | 青青青在线视频观看 | 日本成年免费网站 | AV天堂亚洲区无码先锋影音 | 色婷婷综合久久久久中文一区二 | 成人免费a级毛片无码片在线播放 | 免费看黄色大片 | 丰满少妇aaaaaa爰片毛片 | 精品入口麻豆88视频 | 欧美性受黑人性爽 | 精品乱码一区二区三四区 | 午夜精品久久久久久久传媒 | 精品欧美一区二区三区久久久 | 一级做a爰片久久毛片潮喷 亚州日本乱码一区二区三区 | 久久男人AV资源网站 | 国产v综合v亚洲欧美久久 | 成人一区二区三区视频在线观看 | 美女视频免费是黄的网站高清 | 婷婷久久综合九色综合97最多收藏 | 成人免费网站在线观看 | 91色老久久精品偷偷蜜臀 | 青苹果乐园免费高清资源 | 欧美精品一区二区三区中文欧美人 | 西西人体444WWW大胆无码视频 | 中国娇小与黑人巨大交导演 | 国产一区2 | 欧美成人精品三级网站 | 西川av在线一区二区三区 | 男人操女人视频免费观看 | 91精品国产99久久久久 |