MySQLdb库连接MySQL数据库
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')

热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

Oracle不仅是数据库公司,还是云计算和ERP系统的领导者。1.Oracle提供从数据库到云服务和ERP系统的全面解决方案。2.OracleCloud挑战AWS和Azure,提供IaaS、PaaS和SaaS服务。3.Oracle的ERP系统如E-BusinessSuite和FusionApplications帮助企业优化运营。

MySQL和phpMyAdmin是强大的数据库管理工具。1)MySQL用于创建数据库和表、执行DML和SQL查询。2)phpMyAdmin提供直观界面进行数据库管理、表结构管理、数据操作和用户权限管理。

MySQL与其他编程语言相比,主要用于存储和管理数据,而其他语言如Python、Java、C 则用于逻辑处理和应用开发。 MySQL以其高性能、可扩展性和跨平台支持着称,适合数据管理需求,而其他语言在各自领域如数据分析、企业应用和系统编程中各有优势。

Golang在性能和可扩展性方面优于Python。1)Golang的编译型特性和高效并发模型使其在高并发场景下表现出色。2)Python作为解释型语言,执行速度较慢,但通过工具如Cython可优化性能。

Python更易学且易用,C 则更强大但复杂。1.Python语法简洁,适合初学者,动态类型和自动内存管理使其易用,但可能导致运行时错误。2.C 提供低级控制和高级特性,适合高性能应用,但学习门槛高,需手动管理内存和类型安全。

Python项目中的分层结构探讨在学习Python的过程中,很多初学者会接触到一些开源项目,特别是使用Django框架的项...

安全地处理JSON中的函数和正则表达式在前端开发中,经常需要将JavaScript...

探讨后端开发中的分层架构问题在后端开发中,常见的分层架构包括controller、service和dao...
