python 学习记录-操作mysql

#coding=utf-8
#****Python操作mysql********
import MySQLdb
#连接数据库,host为mysql主机ip,user、passwd为数据库用户名和密码,db为数据库名称,port为端口号默认3306
conn=MySQLdb.connect(host="127.0.0.1",user="root",passwd="123",db="test",port=3306,charset="utf8")
#创建游标
cur=conn.cursor()
#执行sql语句
cur.execute("insert into msg(title,name,content) values('test03','zz03','test03 cntent')")
#执行sql语句后,必须提交事务才执行数据库操作
conn.commit()
#关闭游标
cur.close()
#关闭数据库连接
conn.close()

在这里插入图片描述

import MySQLdb
conn=MySQLdb.connect(host="127.0.0.1",user="root",passwd="123",db="test",port=3306,charset="utf8")
#创建游标
cur=conn.cursor()
#定义一个sql
sql="insert into msg(title,name,content) values(%s,%s,%s)"
#插入多条数据
cur.executemany(sql,[('test04','zz04','test04 content'),('test05','zz05','test05 content'),('test06', 'zz06', 'test06 content')])
conn.commit()
#关闭游标
cur.close()
#关闭数据库连接
conn.close()

在这里插入图片描述

import MySQLdb
conn=MySQLdb.connect(host="127.0.0.1",user="root",passwd="123",db="test",port=3306,charset="utf8")
#创建游标
cur=conn.cursor()
#创建100条数据
for i in range(100):
    sql="insert into msg(title,name,content) values(%s,%s,%s)"
    cur.executemany(sql,[('test'+str(i),'zz'+str(i),'test'+str(i)+' content')])
    conn.commit()
#关闭游标
cur.close()
#关闭数据库连接
conn.close()

在这里插入图片描述

import MySQLdb
conn=MySQLdb.connect(host="127.0.0.1",user="root",passwd="123",db="test",port=3306,charset="utf8")
#创建游标
cur=conn.cursor()
#性别随机
import random
sql="insert into user(name,gender) values "
 for i in range(100):	
    sql += "('user" + str(i) + "'," + str(random.randint(0, 1)) + "),"
#最后一个值有逗号,使用切片把逗号去掉
sql=sql[:-1]
#执行sql操作
cur.execute(sql)
conn.commit()
#关闭游标
cur.close()
#关闭数据库连接
conn.close()

在这里插入图片描述

#****查询数据*********
import MySQLdb
conn=MySQLdb.connect(host="127.0.0.1",user="root",passwd="123",db="test",port=3306,charset="utf8")
#创建游标
cur=conn.cursor()
#1. fetchall():接收全部的返回结果行
cur.execute("select * from msg")
print cur.fetchall()
#2. fetchmany(size=None):接收size条返回结果行,如果size的值大于返回的结果行的数量,则会返回cursor.arraysize条数据
cur.execute("select * from msg")
print cur.fetchmany(size=3)
#3. fetchone():返回一条结果行
cur.execute("select * from msg")
print cur.fetchone()
#4. scroll(value,mode='relative'):移动指针到某一行,如果mode='relative',则表示从当前所在行移动
#value条;如果mode='absolute',则表示从结果集的第一行移动value条
#*********************
cur.execute("select * from msg")
cur.scroll(1,mode='absolute')## 第一条移动value=1行,就是第二行数据
print cur.fetchmany(1)#取1条数据
#*********************
cur.execute("select * from msg")
cur.scroll(1,mode='relative')#从当前所在行在移动一行
print cur.fetchmany(1)

#********操作mysql-执行事务**********************
try:
    cur.execute("drop table test")
    conn.commit()
except:
    #执行失败,回滚操作
    conn.rollback()
#关闭游标
cur.close()
#关闭数据库连接
conn.close()

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值