deepin中mysql数据库的连接_教你如何典雅的用Python连接MySQL数据库
簡介:作者 | Python語音識別不管是機器學(xué)習(xí)、web開發(fā)或者爬蟲,數(shù)據(jù)庫都是繞不過去的。那么今天我們就來介紹Python如何Mysql數(shù)據(jù)庫進行連接以及數(shù)據(jù)的交換。主要分為以下幾個方面:什么是數(shù)據(jù)庫?什么是MySQLdb?Python如 ...
書頁庫概念
作者 | Python語音識別
不管是機器學(xué)習(xí)、web開發(fā)或者爬蟲,數(shù)據(jù)庫都是繞不過去的。那么今天我們就來介紹Python如何Mysql數(shù)據(jù)庫進行連接以及數(shù)據(jù)的交換。主要分為以下幾個方面:
什么是數(shù)據(jù)庫?
什么是MySQLdb?
Python如何連接數(shù)據(jù)庫?
創(chuàng)建數(shù)據(jù)庫數(shù)據(jù)庫操作-CRUD
數(shù)據(jù)庫基本上是結(jié)構(gòu)化數(shù)據(jù)的集合,通過數(shù)據(jù)庫可以用各種方式輕松地檢索,管理和訪問數(shù)據(jù)。最簡單的數(shù)據(jù)庫形式之一是文本數(shù)據(jù)庫。目前關(guān)系數(shù)據(jù)庫是最流行的數(shù)據(jù)庫系統(tǒng),目前主流的關(guān)系數(shù)據(jù)庫主要由以下幾個:
MySQL
Oracle Database
SQL server
Sybase
Informix
IBM db2
NO SQL
其中MySQL是最容易使用的數(shù)據(jù)庫,也是我們這次所要介紹的。什么是MySQLdb
MySQLdb是一個開源免費的關(guān)系數(shù)據(jù)庫管理系統(tǒng),它使用結(jié)構(gòu)化查詢語言。SQL(結(jié)構(gòu)化查詢語言)是關(guān)系數(shù)據(jù)庫的標(biāo)準語言,允許用戶對數(shù)據(jù)進行各種操作,如操作,創(chuàng)建,刪除等。簡而言之,SQL允許您對數(shù)據(jù)執(zhí)行任何操作。Python如何連接數(shù)據(jù)庫
Python連接數(shù)據(jù)庫的方法非常簡單,下圖表示Python與數(shù)據(jù)庫的基本數(shù)據(jù)交換原理。
在連接MySQL數(shù)據(jù)庫之前,請確保在計算機上安裝了MySQL應(yīng)用程序。也可使用遠程數(shù)據(jù)庫,MySQL應(yīng)用程序提供了一下數(shù)據(jù)工具:MySQL服務(wù)器、所有可用連接器、MySQL Workbench、MySQL通知程序、用于Excel和Microsoft Visual Studio的工具、MySQL示例數(shù)據(jù)庫、MySQL文檔。
安裝好應(yīng)用程序之后,我們還需要安裝python中的Mysql函數(shù)庫mysql.connector,這個可以直接使用pip進行安裝。連接數(shù)據(jù)庫需要的基本參數(shù)是:
用戶名 -它只是您為MySQL服務(wù)器工作的用戶名,默認用戶名為root。
密碼 -密碼由用戶在安裝MySQL數(shù)據(jù)庫時提供。我在這里給密碼'password123'
主機名 -這基本上是運行MySQL的服務(wù)器名稱或IP地址,如果它是'localhost',那么你的IP地址是127.0.0.0
以下是Python連接數(shù)據(jù)庫的程序
import mysql.connectormydb=mysql.connector.connect(host="localhost",user="root",passwd="password123")print(mydb)
運行程序輸出為:
C:UsersHarshit_KantPycharmProjectstest1venvScriptspython.exe C:/Users/Harshit_Kant/PycharmProjects/test1/venv/python-db-conn.py
這里'mydb'只是一個示例。從輸出中可以清楚地看到Python已連接到數(shù)據(jù)庫。創(chuàng)建數(shù)據(jù)庫
經(jīng)過上面一步,我們已經(jīng)成功建立數(shù)據(jù)庫連接,現(xiàn)在您就可以創(chuàng)建自己的數(shù)據(jù)庫,它將充當(dāng)python和MySQL服務(wù)器之間數(shù)據(jù)交流的橋梁。建立數(shù)據(jù)庫代碼如下:
import mysql.connectormydb=mysql.connector.connect(host="localhost",user="root",passwd="password123")mycursor=mydb.cursor()mycursor.execute("create database harshdb")
程序說明:
在上面的程序中使用了游標(biāo),它基本上是一個用于與整個MySQL服務(wù)器通信的對象,通過它我可以創(chuàng)建自己的數(shù)據(jù)庫。
您可以從輸出中看到創(chuàng)建了名為“harshdb”的數(shù)據(jù)庫,該數(shù)據(jù)庫是自定義的,因為您可以為數(shù)據(jù)庫指定任何名稱。
同時,如果你想要查看服務(wù)器中已經(jīng)建立的數(shù)據(jù)庫,可以使用以下代碼:
import mysql.connectormydb=mysql.connector.connect(host="localhost",user="root",passwd="password123")mycursor=mydb.cursor()mycursor.execute("show databases")for db in mycursor:print(db)
輸出示例為:
('harshdb')('information_schema')('mysql')('performance_schema')('sakila')('sys')('world')數(shù)據(jù)庫操作
數(shù)據(jù)庫的基本操作包括:創(chuàng)建、讀取、更新和刪除,下面我通過示例程序來為大家演示基本使用方法。
創(chuàng)建操作:用于在表中創(chuàng)建記錄的SQL語句,或者可以說它用于創(chuàng)建表。代碼如下:
import mysql.connectormydb=mysql.connector.connect(host="localhost",user="root",passwd="password123",database=harshdb)mycursor=mydb.cursor()mycursor.execute("create table employee(name varchar(250),sal int(20))")
程序說明:
在上面給出的程序中,我創(chuàng)建了一個表'employee'。
表員工有兩個字段'name'和'sal'。
這里,User id是“root”,Password是“password123”,用于訪問harshdb。
下面給出的屏幕截圖顯示了表'employee'并返回字段'name'和'sal'。
讀取寫入:用于從數(shù)據(jù)庫中獲取有用信息。代碼示例如下:
import mysql.connectormydb=mysql.connector.connect(host="localhost",user="root",passwd="password123",database="harshdb")mycursor=mydb.cursor()sqlformula = "Insert into employee(name,sal) values(%s,%s)"//'values has placeholdersemployees = [("harshit",200000),("rahul", 30000),("avinash", 40000),("amit", 50000),]//Created an array of emplpoyeesmycursor.executemany(sqlformula, employees)//Passing the datamydb.commit()//SQL statement used for saving the changes
在上面的代碼中,我通過在Python中編寫SQL語句寫入一組員工數(shù)據(jù)。寫入之后數(shù)據(jù)庫的屏幕截圖顯示如下:
更新 :用于更新表中的記錄或更新表。代碼如下:
import mysql.connectormydb=mysql.connector.connect(host="localhost",user="root",passwd="password123",database="harshdb")mycursor=mydb.cursor()sql = "Update employee SET sal = 70000 WHERE name = 'harshit'"mycursor.execute(sql)mydb.commit()
程序說明:我們在上面給出的代碼中更新了harshit的行“sal”。下面給出的數(shù)據(jù)庫截圖顯示更新結(jié)果。
刪除 :用于刪除表格。代碼示例如下:
import mysql.connectormydb = mysql.connector.connect(host =“l(fā)ocalhost”,user =“root”,passwd =“password123”,database =“harshdb”)mycursor = mydb.cursor()sql =“DELETE FROM employee WHERE name ='harshit'“mycursor.execute(sql)mydb.commit()
程序說明:在上面的代碼中,我刪除了一條'harshit'的重復(fù)記錄。
Python連接數(shù)據(jù)庫還有一個pymysql函數(shù)包,該包也十分簡單且方便的與數(shù)據(jù)庫進行交互,大家可以嘗試一下。
需要觀看python java web 資料的:
老規(guī)矩:轉(zhuǎn)發(fā)+關(guān)注,私信小編“資料”免費分享資料給你!
總結(jié)
以上是生活随笔為你收集整理的deepin中mysql数据库的连接_教你如何典雅的用Python连接MySQL数据库的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Qt使用socket通信时接收的汉字信息
- 下一篇: mysql用时查询_mysql 常用时间