Python 2.7 学习笔记 访问mysql数据库
一、基本概念
使用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数据库的更多相关文章
- SQLMAP学习笔记2 Mysql数据库注入
SQLMAP学习笔记2 Mysql数据库注入 注入流程 (如果网站需要登录,就要用到cookie信息,通过F12开发者工具获取cookie信息) sqlmap -u "URL" - ...
- [Python] 学习笔记之MySQL数据库操作
1 Python标准数据库接口DB-API介绍 Python标准数据库接口为 Python DB-API,它为开发人员提供了数据库应用编程接口.Python DB-API支持很多种的数据库,你可以选择 ...
- mysql学习笔记之mysql数据库的安装
1.执行mysql安装包选择自己定义安装(安装路径不要带中文,否则安装会出错! ) 2.一个mysql想要操作成功须要有三部分:server端,数据段,数据. 3.server软件文件夹: 4.数据文 ...
- 学习笔记:MySQL数据库初步 概念
数据库 什么是数据库,数据库就是对大量信息进行管理的高效的解决方案,按照数据结构来组织.存储和管理数据的载体.而我们常说的数据库可以分为关系型和非关系型数据库. 关系型数据库 这里说的关系型数据库,是 ...
- PHP学习笔记:MySQL数据库的操纵
Update语句 Update 表名 set 字段1=值1, 字段2=值2 where 条件 练习: 把用户名带 ‘小’的人的密码设置为123456@ 语句:UPDATE crm_user SE ...
- Python访问MySQL数据库并实现其增删改查功能
概述:对于访问MySQL数据库的操作,我想大家也都有一些了解.不过,因为最近在学习Python,以下就用Python来实现它.其中包括创建数据库和数据表.插入记录.删除记录.修改记录数据.查询数据.删 ...
- 【python小记】访问mysql数据库
题记: 最近因为工作需要,学习了python,瞬间对这个轻松快捷的语给吸引了,以前只知道js脚本是写网页的,没有想到python这个脚本语言的应用范围可以这么广泛,现在做一些简单或稍微复杂的操作,基本 ...
- Requests:Python HTTP Module学习笔记(一)(转)
Requests:Python HTTP Module学习笔记(一) 在学习用python写爬虫的时候用到了Requests这个Http网络库,这个库简单好用并且功能强大,完全可以代替python的标 ...
- C#连接、访问MySQL数据库
一.准备工具 visual stuido(本示例使用visual studio 2010) MySql.Data.dll mysql_installer_community_V5.6.21.1_set ...
随机推荐
- NHibernate composite-id联合主键配置
NHibernate的联合主键配置比较复杂,初次配置可能需要花些时间,但只要我们理解了,掌握一定的步骤还是很容易的. 1.设计数据结构 Users:用户表 名称 Users 说明 用户表 序号 字段名 ...
- JAVA中SSH面试问题
1.阐述struts2的执行流程. Struts 2框架本身大致可以分为3个部分:核心控制器FilterDispatcher.业务控制器Action和用户实现的企业业务逻辑组件.核心控制器Filter ...
- lightoj Again Array Queries
1100 - Again Array Queries PDF (English) Statistics Forum Time Limit: 3 second(s) Memory Limit: 32 ...
- Android的重力传感器(3轴加速度传感器)简单实例
重力感应主要是依靠手机的加速度传感器(accelerometer)来实现 在Android的开发中一共有八种传感器但是不一定每一款真机都支持这些传感器.因为很多功能用户根本不care的所以可能开发商会 ...
- Matlab pivotgolf
function scoreout = pivotgolf(course,pivotstrat) % PIVOTGOLF Pivot Pickin' Golf. % Your goal is to u ...
- 【已解决】谁动了我的CurrentPrincipal?求助我在给Artech的wcf petshop增加授权机制的时候遇到的问题。
这个问题已解决,是绑定设置的问题,主要还是因为我自己没有深入理解WCF绑定的安全机制.在这篇博客里面我来说说怎么解决的. 下载了Artech的wcf petshop源码(博文链接)并调试运行成功后,打 ...
- 百度前端技术学院Html&CSS学习资源
Web相关名词通俗解释 https://www.zhihu.com/question/22689579 MDN HTML入门 https://developer.mozilla.org/zh-CN/d ...
- JavaScript 数字相关的转换和方法
类型判断 isNaN - 是否是 NaN(Not a Number).主要用来判断 NaN 是否是 NaN,因为 NaN == NaN 是 false. isNaN(NaN); // tr ...
- 利用jQuery获取数据,JSONP
最近工作用到了跨域请求,所以此文就有了,概念网上都有,就不细说了,直接来了. 看了一篇文章,说的是通过扩展让ASP.NET Web API支持JSONP,jsonp网上有很多的教程,js代码部分基本和 ...
- linux下操作gpio寄存器的方法
一. 在驱动中: 1. 用的时候映射端口:ioremap; #define GPIO_OFT(x) ((x) - 0x56000000) #define GPFCON (*(volatile unsi ...