MySQL Python指南

关于MySQL数据库

MySQL是业界领先的开源数据库管理系统。它是多用户、多线程数据库管理系统。MySQL在互联网特别流行,它是LAMP平台的其中一个部分,主要组成部分是Linux,Apache,MySQL和PHP。现在MySQL属于Oracle。MySQL数据库在适应于大部分的操作系统。它可以运行在BSD Unix,Linux,Windows或Mac OS。Wikipedia 和 YouTube都使用 MySQL. 这些站点每天处理百万级的查询。

开始之前

我们需要安装几个包来执行本指南中的例子。
MySQL官网查找合适你操作系统的MySQL下载包

另外到MySQL-Python下载Python版本的MySQL驱动,从而可以在Python和MySQL之间建立联系。

接下来,我们准备创建个新数据库用户和新数据库,使用MySQL客户端来完成这些操作。
进入命令行,如果是Windows系统,切换目录到你的MySQL的bin目录
比如C:\Program Files\MySQL\MySQL Server 5.7\bin
然后执行$ mysql -u root -p
输入密码。
你会得到如下界面:

C:\Program Files\MySQL\MySQL Server 5.7\bin>mysql -u root -p
Enter password: *******
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 24
Server version: 5.7.12-log MySQL Community Server (GPL)

Copyright (c) 2000, 2016, 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.

查看数据库

Database
information_schema
mysql
performance_schema
test

mysql> show databases;

Database
information_schema
mysql
performance_schema
test

我们使用root账户连到数据库,用show databases语句可以得到所有可用的数据库。

mysql> CREATE DATABASE testdb;
我们建立一个数据库testdb,然后在本指南中使用这个数据库。

mysql> CREATE USER 'testuser'@'localhost' IDENTIFIED BY 'test623';
创建一个用户testuser

mysql> USE testdb;
这个语句是在本指南中一直使用数据库testdb。

mysql> GRANT ALL ON testdb.* TO 'testuser'@'localhost';
给testuser赋予所有权限。

mysql> quit;
到目前为止,我们建立了个新数据库用户,我们把所有权限赋给这个用户可以操作这个数据库中的所有表。

MySQLdb 模块

First example

在第一个例子里面,我们来获取MySQL数据库的版本号。

#! /usr/bin/env python
#coding=utf-8
import MySQLdb as mdb
import sys

try:
    conn = mdb.connect("localhost", "testuser", "test623", "testdb")
    cursor = conn.cursor()
    
    cursor.execute("select version()")
    
    results = cursor.fetchone()
    print "Database version: %s" % results
except mdb.Error, e:
    print "Error %d: %s" % (e.args[0], e.args[1])
    sys.exit(1)

finally:
    if conn:
        conn.close()

在这个脚本里,我们连接数据库并执行select version()语句。这会返回当前MySQL数据库的版本号。

import MySQLdb as mdb: 导入MySQLdb模块。

conn = mdb.connect('localhost', 'testuser', 'test623', 'testdb');: 连接数据库。
connect()方法有四个参数:第一个参数是host,MySQL坐落的地方;在我们的例子中是localhost,即本机。第二个参数是数据库用户名,紧接着的是数据库用户密码。最后一个参数是数据库的名称。

cursor.execute("select version")```
我们从连接上得到cursor对象,cursor用来在结果集中遍历记录。我们调用**execute()**方法来执行这个SQL语句.

```results = cur.fetchone()```:获取数据,考虑到我们只拿一个数据,因此调用**fetchone()**方法.

## 建立表并插入一些数据

! /usr/bin/env python

coding=utf-8

import MySQLdb as mdb

conn = mdb.connect("localhost", "testuser", "test623", "testdb")

with conn:
cursor = conn.cursor()
cursor.execute("drop table if exists writers")
cursor.execute("CREATE TABLE writers(Id INT PRIMARY KEY AUTO_INCREMENT, Name VARCHAR(25))")
cursor.execute("INSERT INTO writers(Name) VALUES('Jack London')")
cursor.execute("INSERT INTO writers(Name) VALUES('Honore de Balzac')")
cursor.execute("INSERT INTO writers(Name) VALUES('Lion Feuchtwanger')")
cursor.execute("INSERT INTO writers(Name) VALUES('Emile Zola')")
cursor.execute("INSERT INTO writers(Name) VALUES('Truman Capote')")


with conn:
通过with关键字,Python解释器自动释放资源,同时也提供错误处理。


## 取得数据

! /usr/bin/env python

coding=utf-8

import MySQLdb as mdb

conn = mdb.connect("localhost", "testuser", "test623", "testdb")

with conn:
cursor = conn.cursor()
cursor.execute("select * from writers")

rows = cursor.fetchall()

for row in rows:
    print row
在本例中,我们取得writers表中的所有数据。

**fetchall()**方法得到所有的记录。它返回一个结果集。它是一个元祖的元祖。每一个内部的元祖都代表表的一行记录。


## 一个一个取得数据

! /usr/bin/env python

coding=utf-8

import MySQLdb as mdb

conn = mdb.connect("localhost", "testuser", "test623", "testdb")

with conn:
cursor = conn.cursor()
cursor.execute("select * from writers")

for i in range(cursor.rowcount):
    row = cursor.fetchone()
    print row[0], row[1]```

字典游标

MySQLdb模块有几种游标类型。默认的游标以元祖的元祖形式返回数据。当我们使用字典游标的时候,数据以Python字典的形式发送。我们可以以列名称的形式访问数据。

#! /usr/bin/env python
#coding=utf-8
import MySQLdb as mdb

conn = mdb.connect("localhost", "testuser", "test623", "testdb")

with conn:
    cursor = conn.cursor(mdb.cursors.DictCursor)
    cursor.execute("select * from writers limit 4")
    
    rows = cursor.fetchall()
    
    for row in rows:
        print row["Id"], row["Name"]

列的头部

接下来,我们展示如何打印列的头部。.

#! /usr/bin/env python
#coding=utf-8
import MySQLdb as mdb

conn = mdb.connect("localhost", "testuser", "test623", "testdb")

with conn:
    cursor = conn.cursor(mdb.cursors.DictCursor)
    cursor.execute("select * from writers limit 5")
    
    rows = cursor.fetchall()
    
    desc = cursor.description
    
    print "%s %3s" % (desc[0][0], desc[1][0])

预处理语句

我们开始编写预处理语句时候,我们使用占位符而不是直接在语句里面写值。预处理语句增强了安全性和性能。Python数据库API规范建议了5种不同的方法来建立预处理语句。MySQLDB支持其中一种, ANSI printf 格式代码.

#! /usr/bin/env python
#coding=utf-8
import MySQLdb as mdb

conn = mdb.connect("localhost", "testuser", "test623", "testdb")
with conn:
    cur = conn.cursor()
    cur.execute("update writers set name=%s where id=%s", ("Guy de manpasant", "4"))
    
    print "number of rows updated:", cur.rowcount
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,098评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,213评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,960评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,519评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,512评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,533评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,914评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,574评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,804评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,563评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,644评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,350评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,933评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,908评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,146评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,847评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,361评论 2 342

推荐阅读更多精彩内容