python数据库操作以及简单的封装

2018-12-21  本文已影响0人  Chris_Cui

封装成类方法使用

class cxt_connetMyql(object):
    def __init__(self, host, user, password, db, port):
        self.host = host
        self.user = user
        self.password = password
        self.db = db
        self.port = port
        self.__getCursor()

    def __getCursor(self):
        try:
            self.conn = pymysql.connect(self.host, self.user, self.password, self.db, self.port, charset='utf8',  use_unicode=True)
        except Exception as e:
            print('数据库链接失败:', e)
        finally:
            self.cursor = self.conn.cursor()
            # 设置游标的编码
            self.cursor.execute('SET NAMES utf8;')
            self.cursor.execute('SET CHARACTER SET utf8;')
            self.cursor.execute('SET character_set_connection=utf8;')

    def executeSelectSql(self, sql):
        try:
            self.cursor.execute(sql)
        except Exception as e:
            print('执行查询SQL失败,错误信息:', e)
        finally:
            return self.cursor.fetchall()

    def executeOtherSql(self, sql):
        try:
            self.cursor.execute(sql)
        except Exception as e:
            print('执行SQL语句失败,错误信息:', e)
        finally:
            self.conn.commit()

    def __del__(self):

        self.cursor.close()
        self.conn.close()

类方法调用

selectUserInfoSql='xxx'
updateCreditSql='xxx'
updateUserStatusSql='xxx'

con = cxt_connetMyql('xxx', 'xxx', 'xxx', 'xxx', xxx)
result1 = con.executeSelectSql(selectUserInfoSql)
con.executeOtherSql(updateUserStatusSql)
result3 = con.executeSelectSql(selectUserInfoSql)
print(result1, result3)

python操作mysql数据库

import pymysql
# 连接
try:
    conn = pymysql.connect(host='xxx', user='xxx', password='xxx', db='xxx', port=xxx)
except Exception as e:
    print('数据库连接出错,报错信息:%s',e)
finally:
    # 游标
    cursor = conn.cursor()

# SQL语句
# 查询用户信息SQL
selectUserInfoSql = "xxx"
# 修改用户信用额度SQL
updateCreditSql = 'xxx'
# 修改用户认证状态SQL
updateUserStatusSql = 'xxx'
# 执行SQL
try:
    cursor.execute(selectUserInfoSql)
    cursor.execute(updateCreditSql)
    cursor.execute(selectUserInfoSql)
except Exception as e:
    print('执行sql语句报错,报错信息:%s',e)
finally:
    # 获取查询的所有记录
    result = cursor.fetchall()
    print(result)

# 关闭游标关闭连接
cursor.close()
conn.close()
import pymysql
from pymysql.cursors import DictCursor
# coon = pymysql.connect(host='211.149.218.16',port=3306,user='jxz',passwd='123456',db='jxz',charset='utf8')
# cur = coon.cursor(DictCursor)#建立游标,仓库管理员,指定游标类型,返回字典
# sql='select * from stu limit 2,9;'
# # insert_sql = 'insert into stu VALUE (89,"nhy");'
# # cur.execute(insert_sql)
# cur.execute(sql)#执行sql语句
# for c in cur:#直接循环游标,每次循环的时候就是每一列的数据
#     print(c)
# # res = cur.fetchall()#获取sql语句执行的结果,一次性全部获取
# # coon.commit()#提交
# # print(res[0][1])
# cur.close()
# coon.close()
def op_mysql(host,user,passwd,db,sql,charset='utf8',port=3306):
    import pymysql
    from pymysql.cursors import DictCursor
    coon = pymysql.connect(host=host,user=user,passwd=passwd,db=db,charset=charset,port=port)
    cur = coon.cursor(DictCursor)#指订返回数据的类型是字典
    cur.execute(sql)
    if sql.strip().startswith('select'):
        res = cur.fetchall()
    else:
        coon.commit()
        res = 'ok'
    cur.close()
    coon.close()
    print(res)
    return res
上一篇 下一篇

猜你喜欢

热点阅读