首页 数据库 mysql教程 MySQLdb库连接MySQL数据库

MySQLdb库连接MySQL数据库

Jun 07, 2016 pm 03:47 PM
db mysql python 数据库 连接

Python DB-API是Python的数据库应用程序接口,支持包括Oracle,MySQL,DB2,MSSQL,Sybase等主流数据库,但不同的数据库,需要下载不同的模块,比如说:MySQLdb模块支持MySQL. 虽然模不一样,但所有这些API执行步骤是一致的: 1. 导入API模 2. 获取与数据库的连接

Python DB-API是Python的数据库应用程序接口,支持包括Oracle,MySQL,DB2,MSSQL,Sybase等主流数据库,但不同的数据库,需要下载不同的模块,比如说:MySQLdb模块支持MySQL. 虽然模不一样,但所有这些API执行步骤是一致的:

1. 导入API模
2. 获取与数据库的连接.
3. 发出SQL语句和存储过程.
4. 关闭连接


下面以MySQLdb模块来做说明:

安装

首先必须安装。Windows下载链接:http://www.codegood.com/archives/4


插入

#导入相关模块
import MySQLdb

#建立和mysql数据库的连接
dbconn = MySQLdb.connect(host='127.0.0.1',user='root',passwd='abcd')
#获取游标
cursor = dbconn.cursor()
#执行SQL,创建一个数据库
cursor.execute("drop database if exists test")
cursor.execute("create database test")
#选择连接哪个数据库
dbconn.select_db('test')
#引入异常处理
try:
    #执行SQL,创建一个表
	cursor.execute("create table log(id int,message varchar(50))")
    #插入一条记录
	value = [0,"Log Information ID is:0"]
	cursor.execute("insert into log values(%s,%s)",value)
    #插入多条记录
	values = []
	for i in range(1,11):
		values.append((i,'Log Information ID is:' + str(i)))
	cursor.executemany("insert into log values(%s,%s)",values)
    #提交修改                               
	dbconn.commit()
except:
    #如果执行SQL语句有错,则回滚!
	dbconn.rollback()
#关闭游标连接,释放资源
cursor.close()
#关闭连接
dbconn.close()
登录后复制

查询

数据库建立连接后,可以使用fetchone()方法来获取单个记录或者fetchAll方法fetech从数据库表的多个值. 
fetchone(): 这种方法获取查询结果集的下一行。结果集是一个对象时,将返回一个游标对象用于查询表.
fetchall(): 这种方法获取结果集的所有行。如果某些行已经从结果集中提取,fetchAll()方法检索结果集的其余行.
rowcount: 这是一个只读属性,返回受影响的行数execute()方法.

#导入模块
import MySQLdb  

#也可以将数据库名放到Connect()
dbconn = MySQLdb.Connection('127.0.0.1', 'root', 'abcd', 'test')  
cursor = dbconn.cursor()  
count = cursor.execute('select * from log')  
print '总共有 %s 条记录',count  
 
#获取一条记录,每条记录做为一个元组返回  
print "只获取一条记录:" 
result = cursor.fetchone();  
print result 
print 'ID: %s   Log Info: %s' % result   
 
#获取5条记录,注意由于之前执行有了fetchone(),所以游标已经指到第二条记录了,也就是从第二条开始的所有记录  
print "只获取5条记录:" 
results = cursor.fetchmany(5)  
for res in results:  
    print res  
 
print "获取所有结果:" 
#重置游标位置,0,为偏移量,mode=absolute | relative,默认为relative,  
cursor.scroll(0,mode='absolute')  
#获取所有结果  
results = cursor.fetchall()  
for res in results:  
    print res  
dbconn.close()  
登录后复制
C:\Work\Python\Learn>python select.py
总共有 %s 条记录 11
只获取一条记录:
(0L, 'Log Information ID is:0')
ID: 0   Log Info: Log Information ID is:0
只获取5条记录:
(1L, 'Log Information ID is:1')
(2L, 'Log Information ID is:2')
(3L, 'Log Information ID is:3')
(4L, 'Log Information ID is:4')
(5L, 'Log Information ID is:5')
获取所有结果:
(0L, 'Log Information ID is:0')
(1L, 'Log Information ID is:1')
(2L, 'Log Information ID is:2')
(3L, 'Log Information ID is:3')
(4L, 'Log Information ID is:4')
(5L, 'Log Information ID is:5')
(6L, 'Log Information ID is:6')
(7L, 'Log Information ID is:7')
(8L, 'Log Information ID is:8')
(9L, 'Log Information ID is:9')
(10L, 'Log Information ID is:10')
登录后复制



本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
威尔R.E.P.O.有交叉游戏吗?
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

Python:自动化,脚本和任务管理 Python:自动化,脚本和任务管理 Apr 16, 2025 am 12:14 AM

Python在自动化、脚本编写和任务管理中表现出色。1)自动化:通过标准库如os、shutil实现文件备份。2)脚本编写:使用psutil库监控系统资源。3)任务管理:利用schedule库调度任务。Python的易用性和丰富库支持使其在这些领域中成为首选工具。

vscode 扩展是否是恶意的 vscode 扩展是否是恶意的 Apr 15, 2025 pm 07:57 PM

VS Code 扩展存在恶意风险,例如隐藏恶意代码、利用漏洞、伪装成合法扩展。识别恶意扩展的方法包括:检查发布者、阅读评论、检查代码、谨慎安装。安全措施还包括:安全意识、良好习惯、定期更新和杀毒软件。

vscode怎么在终端运行程序 vscode怎么在终端运行程序 Apr 15, 2025 pm 06:42 PM

在 VS Code 中,可以通过以下步骤在终端运行程序:准备代码和打开集成终端确保代码目录与终端工作目录一致根据编程语言选择运行命令(如 Python 的 python your_file_name.py)检查是否成功运行并解决错误利用调试器提升调试效率

vscode是什么 vscode是干什么用的 vscode是什么 vscode是干什么用的 Apr 15, 2025 pm 06:45 PM

VS Code 全称 Visual Studio Code,是一个由微软开发的免费开源跨平台代码编辑器和开发环境。它支持广泛的编程语言,提供语法高亮、代码自动补全、代码片段和智能提示等功能以提高开发效率。通过丰富的扩展生态系统,用户可以针对特定需求和语言添加扩展程序,例如调试器、代码格式化工具和 Git 集成。VS Code 还包含直观的调试器,有助于快速查找和解决代码中的 bug。

Python vs. JavaScript:学习曲线和易用性 Python vs. JavaScript:学习曲线和易用性 Apr 16, 2025 am 12:12 AM

Python更适合初学者,学习曲线平缓,语法简洁;JavaScript适合前端开发,学习曲线较陡,语法灵活。1.Python语法直观,适用于数据科学和后端开发。2.JavaScript灵活,广泛用于前端和服务器端编程。

vscode 可以在 mac 上吗 vscode 可以在 mac 上吗 Apr 15, 2025 pm 07:45 PM

VS Code 在 macOS 上表现良好,可提升开发效率。安装和配置步骤包括:安装 VS Code 并进行配置。安装特定语言的扩展(如 JavaScript 的 ESLint)。谨慎安装扩展,避免过多导致启动变慢。学习基本功能,如 Git 集成、终端和调试器。设置合适的主题和代码字体。注意潜在问题:扩展兼容性、文件权限等。

vscode 无法运行 python怎么回事 vscode 无法运行 python怎么回事 Apr 15, 2025 pm 06:00 PM

最常见的“无法运行 Python”问题源于 Python 解释器路径的错误配置,解决方法包括:确认 Python 安装、配置 VS Code、使用虚拟环境。除此之外,还有断点调试、变量监视、日志输出、代码格式化等高效的调试技巧和最佳实践,如使用虚拟环境隔离依赖,使用断点追踪代码执行,使用监视表达式实时跟踪变量变化等,这些能大幅提高开发效率。

vs code 可以运行 python 吗 vs code 可以运行 python 吗 Apr 15, 2025 pm 08:21 PM

是的,VS Code 可以运行 Python 代码。为在 VS Code 中高效运行 Python,请完成以下步骤:安装 Python 解释器并配置环境变量。安装 VS Code 中的 Python 扩展。通过命令行在 VS Code 的终端中运行 Python 代码。利用 VS Code 的调试功能和代码格式化来提高开发效率。采用良好的编程习惯并使用性能分析工具优化代码性能。

See all articles