一、基本概念

使用python操作数据库,其基本的流程如下(其实所有开发语言访问数据库的流程都是这样)。

1、第一,引入相应数据库的python数据库接口模块,针对不同的数据库类型,有不同的数据库访问接口模块。可以理解这些接口模块提供了一些api接口,让python代码可以访问数据库。

2、获取数据库的连接

3、执行sql语句

4、关闭数据库连接

二、下载python数据库接口包

比如对应mysql数据库,首先要下载相应的python mysql包。

可以到 https://pypi.python.org/pypi/MySQL-python/1.2.5 这个链接下下载,

对于windows系统,会有exe安装包,安装后,会在 Python27\Lib\site-packages 目录下生成mysql的包

三、代码编写

表结构如下: create table test(id int,info varchar(100))

#coding=utf-8
import time
import MySQLdb
try:
conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='',db='dpms',port=3306)
cur=conn.cursor()
cur.execute('insert into test values(0,"x0")')
conn.commit()
cur.close()
conn.close()
print "finish insert direct"
except MySQLdb.Error,e:
print e.args[1] try:
conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='',db='dpms',port=3306)
cur=conn.cursor()
cur.execute('insert into test values(%s,%s)',(1,"x1"))
cur.execute('insert into test values(%s,%s)',[2,"x2"])
conn.commit()
cur.close()
conn.close()
print "finish insert by para"
except MySQLdb.Error,e:
print e.args[1] try:
conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='',db='dpms',port=3306)
cur=conn.cursor()
data=[];
data.append((3,"x3"));
data.append((4,"x4"));
cur.executemany('insert into test values(%s,%s)',data)
data=[];
data.append([5,"x5"]);
data.append([6,"x6"]);
cur.executemany('insert into test values(%s,%s)',data)
conn.commit()
cur.close()
conn.close()
print "finish muti insert by para"
except MySQLdb.Error,e:
print e.args[1] try:
conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='',db='dpms',port=3306)
cur=conn.cursor()
cur.execute('select * from test where id=%s',('')) #数字参数?
res=cur.fetchall()
for re in res:
print "id=%s,info=%s" % (re[0],re[1])
cur.close()
conn.close()
print "finish query where"
except MySQLdb.Error,e:
print e.args[1] try:
conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='',db='dpms',port=3306)
cur=conn.cursor()
cur.execute('select * from test')
res=cur.fetchall()
for re in res:
print "id=%s,info=%s" % (re[0],re[1])
cur.close()
conn.close()
print "finish query fetchall"
except MySQLdb.Error,e:
print e.args[1] try:
conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='',db='dpms',port=3306)
cur=conn.cursor()
cur.execute('select * from test') #游标指向第一条记录
re = cur.fetchone() #获取当前游标记录,同时游标指向下一条记录
print "id=%s,info=%s" % (re[0],re[1])
re = cur.fetchone()
print "id=%s,info=%s" % (re[0],re[1])
res=cur.fetchall() #获取当前游标记录及后续所有记录
for re in res:
print "id=%s,info=%s" % (re[0],re[1])
cur.close()
conn.close()
print "finish query fetchone"
except MySQLdb.Error,e:
print e.args[1] try:
conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='',db='dpms',port=3306)
cur=conn.cursor()
cur.execute('delete from test')
conn.commit()
cur.close()
conn.close()
print "finish delete"
except MySQLdb.Error,e:
print e.args[1]

需要说明的是,如果python脚本的字符集编码与数据库的字符集不一致,中文会出现乱码。

解决方法是在获取链接时指定数据库的字符集。如:

conn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='',db='dpms',port=3306,charset='gbk')

上面语句通过 增加 charset='gbk' 指定数据库的字符集。

Python 2.7 学习笔记 访问mysql数据库的更多相关文章

  1. SQLMAP学习笔记2 Mysql数据库注入

    SQLMAP学习笔记2 Mysql数据库注入 注入流程 (如果网站需要登录,就要用到cookie信息,通过F12开发者工具获取cookie信息) sqlmap -u "URL" - ...

  2. [Python] 学习笔记之MySQL数据库操作

    1 Python标准数据库接口DB-API介绍 Python标准数据库接口为 Python DB-API,它为开发人员提供了数据库应用编程接口.Python DB-API支持很多种的数据库,你可以选择 ...

  3. mysql学习笔记之mysql数据库的安装

    1.执行mysql安装包选择自己定义安装(安装路径不要带中文,否则安装会出错! ) 2.一个mysql想要操作成功须要有三部分:server端,数据段,数据. 3.server软件文件夹: 4.数据文 ...

  4. 学习笔记:MySQL数据库初步 概念

    数据库 什么是数据库,数据库就是对大量信息进行管理的高效的解决方案,按照数据结构来组织.存储和管理数据的载体.而我们常说的数据库可以分为关系型和非关系型数据库. 关系型数据库 这里说的关系型数据库,是 ...

  5. PHP学习笔记:MySQL数据库的操纵

    Update语句 Update 表名 set 字段1=值1, 字段2=值2  where  条件 练习: 把用户名带  ‘小’的人的密码设置为123456@ 语句:UPDATE crm_user SE ...

  6. Python访问MySQL数据库并实现其增删改查功能

    概述:对于访问MySQL数据库的操作,我想大家也都有一些了解.不过,因为最近在学习Python,以下就用Python来实现它.其中包括创建数据库和数据表.插入记录.删除记录.修改记录数据.查询数据.删 ...

  7. 【python小记】访问mysql数据库

    题记: 最近因为工作需要,学习了python,瞬间对这个轻松快捷的语给吸引了,以前只知道js脚本是写网页的,没有想到python这个脚本语言的应用范围可以这么广泛,现在做一些简单或稍微复杂的操作,基本 ...

  8. Requests:Python HTTP Module学习笔记(一)(转)

    Requests:Python HTTP Module学习笔记(一) 在学习用python写爬虫的时候用到了Requests这个Http网络库,这个库简单好用并且功能强大,完全可以代替python的标 ...

  9. C#连接、访问MySQL数据库

    一.准备工具 visual stuido(本示例使用visual studio 2010) MySql.Data.dll mysql_installer_community_V5.6.21.1_set ...

随机推荐

  1. GoWithTheFlow

    GoWithTheFlow http://notes.jetienne.com/2011/07/17/gowiththeflow.js-async-flow-control-with-a-zen-to ...

  2. Linux Centos 系统上安装BT客户端 Transmission

    Linux Centos 系统上安装BT客户端 Transmission   Transmission是一种BitTorrent客户端,特点是一个跨平台的后端和其上的简洁的用户界面,以MIT许可证和G ...

  3. kinect for windows - SkeletonBasics-D2D详解之二

    首先看骨骼追踪例子代码的结构:

  4. 测试横竖屏切换时activity 的生命周期

    对于这个面试题,相信大家都见过,网上给出的答案是: 1.不设置Activity的android:configChanges时,切屏会重新调用各个生命周期,切横屏时会执行一次,切竖屏时会执行两次 2.设 ...

  5. 用javap命令反编译来分析字符串问题

    编写Test.java.编译完后生成Test.class文件,然后对该文件运行javap -c Test命令,生成字节码指令.阅读并得出结论 一.s1和s2指向常量池的不同常量 ①java代码 pub ...

  6. [译]在 64bit 环境中执行32 bit的SSIS包

    最近碰到了一个众所周知的32bit的 SSIS 包在64bit的SQL Server环境的执行问题. 我看了一些解决方案,比如修改在SSDT里面修改 debug 选项(Run64BitRuntime ...

  7. Linux命令压缩与解压缩

    zip格式的文件:zip和unzip zip 命令: # zip test.zip test.txt 它会将 test.txt 文件压缩为 test.zip ,当然也可以指定压缩包的目录,例如 /ro ...

  8. 【Visual C++】游戏开发五十六 浅墨DirectX教程二十三 打造游戏GUI界面(一)

    本系列文章由zhmxy555(毛星云)编写,转载请注明出处. 文章链接:http://blog.csdn.net/poem_qianmo/article/details/16384009 作者:毛星云 ...

  9. 《JavaScript权威指南》拾遗(上)

    一.语言基础         1.javascript中,只有null和undefined是无法拥有方法的值,它们都没有包装对象.typeof null == ‘object' , typeof un ...

  10. python2.7_1.3_获取远程设备的IP地址

    代码如下: # -*- coding: utf-8 -*- import socket def get_remote_machine_info(): remote_host = 'www.python ...