Home Database Mysql Tutorial MySQLdb库连接MySQL数据库

MySQLdb库连接MySQL数据库

Jun 07, 2016 pm 03:47 PM
db mysql python database connect

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()
Copy after login

查询

数据库建立连接后,可以使用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()  
Copy after login
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')
Copy after login



Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Choosing Between PHP and Python: A Guide Choosing Between PHP and Python: A Guide Apr 18, 2025 am 12:24 AM

PHP is suitable for web development and rapid prototyping, and Python is suitable for data science and machine learning. 1.PHP is used for dynamic web development, with simple syntax and suitable for rapid development. 2. Python has concise syntax, is suitable for multiple fields, and has a strong library ecosystem.

PHP and Python: Different Paradigms Explained PHP and Python: Different Paradigms Explained Apr 18, 2025 am 12:26 AM

PHP is mainly procedural programming, but also supports object-oriented programming (OOP); Python supports a variety of paradigms, including OOP, functional and procedural programming. PHP is suitable for web development, and Python is suitable for a variety of applications such as data analysis and machine learning.

MySQL's Role: Databases in Web Applications MySQL's Role: Databases in Web Applications Apr 17, 2025 am 12:23 AM

The main role of MySQL in web applications is to store and manage data. 1.MySQL efficiently processes user information, product catalogs, transaction records and other data. 2. Through SQL query, developers can extract information from the database to generate dynamic content. 3.MySQL works based on the client-server model to ensure acceptable query speed.

Golang vs. Python: Concurrency and Multithreading Golang vs. Python: Concurrency and Multithreading Apr 17, 2025 am 12:20 AM

Golang is more suitable for high concurrency tasks, while Python has more advantages in flexibility. 1.Golang efficiently handles concurrency through goroutine and channel. 2. Python relies on threading and asyncio, which is affected by GIL, but provides multiple concurrency methods. The choice should be based on specific needs.

Python vs. JavaScript: The Learning Curve and Ease of Use Python vs. JavaScript: The Learning Curve and Ease of Use Apr 16, 2025 am 12:12 AM

Python is more suitable for beginners, with a smooth learning curve and concise syntax; JavaScript is suitable for front-end development, with a steep learning curve and flexible syntax. 1. Python syntax is intuitive and suitable for data science and back-end development. 2. JavaScript is flexible and widely used in front-end and server-side programming.

Python: Automation, Scripting, and Task Management Python: Automation, Scripting, and Task Management Apr 16, 2025 am 12:14 AM

Python excels in automation, scripting, and task management. 1) Automation: File backup is realized through standard libraries such as os and shutil. 2) Script writing: Use the psutil library to monitor system resources. 3) Task management: Use the schedule library to schedule tasks. Python's ease of use and rich library support makes it the preferred tool in these areas.

How to run python with notepad How to run python with notepad Apr 16, 2025 pm 07:33 PM

Running Python code in Notepad requires the Python executable and NppExec plug-in to be installed. After installing Python and adding PATH to it, configure the command "python" and the parameter "{CURRENT_DIRECTORY}{FILE_NAME}" in the NppExec plug-in to run Python code in Notepad through the shortcut key "F6".

Golang vs. Python: Key Differences and Similarities Golang vs. Python: Key Differences and Similarities Apr 17, 2025 am 12:15 AM

Golang and Python each have their own advantages: Golang is suitable for high performance and concurrent programming, while Python is suitable for data science and web development. Golang is known for its concurrency model and efficient performance, while Python is known for its concise syntax and rich library ecosystem.

See all articles