zoukankan      html  css  js  c++  java
  • 8.2.3 操作MySQL数据库

      Python访问MySQL数据库可以使用MySQLDb模块,该模块主要方法如下:

        (1)commit():提交事务。

        (2)rollback():回滚事务。

        (3)callproc(self,procname,args):用来执行存储过程,接受的参数为存储过程名和参数列表,反回值为受影响的行数。

        (4)execute(self,query,ages):执行单条SQL语句,接收侧参数为SQL语句中本身和使用的参数列表,返回值为受影响的行数。

        (5)executemany(self,query,args):执行单条SQL语句,但是重复执行参数列表里的参数,返回值为受影响的函数。

        (6)nextset(self):移到下一个结果集。

        (7)fetchall(self):接收全部的返回结果行。

        (8)fetchmany(self,size=None):接收size条返回结果,如果size的值大于返回结果行的数量,则会返回cursor.arraysize条数据。

        (9)fetchone(self):返回一条结果行。

        (10)scroll(self,value,mode='relative'):移动指针到某一行,如果mode=‘relative’,则表示从当前所在行移动value条记录;如果mode='absoulte',则表示从结果集的第一行移动value条记录。

     1 import MySQLdb
     2 
     3 #从MySQL数据库中查询数据
     4 
     5 try:
     6         conn = MySQLdb.connect(host='localhost',user='root',passwd='root',db='test',port=3306)
     7         cur = conn.cursor()
     8         cur.execute('select * from user')
     9         cur.close()
    10         conn.close()
    11 except MySQLdb.Error as e:
    12     print('MySQL Error %d:%s'%(e.args[0],e.args[1]))
    13 
    14 
    15 #往MySQL数据库中插入数据
    16 try:
    17     conn = MySQLdb.connect(host='localhost', user='root', passwd='root', db='test', port=3306)
    18     cur = conn.cursor()
    19     cur.execute('create database if not exists python')
    20     conn.select_db('python')
    21     cur.execute('create table test(id int,info varchar(20))')
    22     value=[1,'hi rollen']
    23     cur.execute('insert into test values(%s,%s)',value)
    24     values = []
    25     for i in range(20):
    26         values.append((i,'hi rollen'+str(i)))
    27         
    28     cur.executemany('insert into test values(%s,%s)',values)
    29     cur.execute('update test set info = "I am rollen" where id = 3')
    30     conn.commit()
    31     cur.close()
    32     conn.close()
    33 except MySQLdb.Error as e:
    34     print('MySQL Error %d:%s' % (e.args[0], e.args[1]))
  • 相关阅读:
    poj2528Mayor's posters(线段树加离散化)第一次接触离散化 做的挺辛苦的
    poj1789Truck History(简单最小生成树)
    【洛谷P2468】粟粟的书架
    【洛谷P3523】DYNDynamite
    【SP1716】GSS3 Can you answer these queries III
    【洛谷P3320】寻宝游戏
    【洛谷P3322】排序
    【GMOJ6293】迷宫
    【GMOJ4051】序列统计
    【洛谷P4719】【模板】动态 DP
  • 原文地址:https://www.cnblogs.com/avention/p/8972366.html
Copyright © 2011-2022 走看看