为了账号安全,请及时绑定邮箱和手机立即绑定

python操作数据库

标签:
Python

python操作数据库需要用到第三方库,本人目前使用的是PyCharm作为编译工具,写python的大多数人应该都用的是这个。关于它的一些使用技巧可以参考PyCharm使用笔记,在此不做赘述。

安装MySQL的第三方库

File --> Setting --> Project:项目名 --> Project Interpreter 点击页面中的+号,在出现的搜素框中输入自己查找的第三库名称即可,最后单击左下方的Install Package开始安装。安装成功会出现如图展示的绿色提示信息,即表示安装成功,在代码中导入使用即可。

webp

安装第三方库


如果安装失败,则进入终端通过pip命令pip install MySQL(或者其它你安装失败的第三库名)来进行安装。之后在通过配置运行python的环境即可。但要注意建立的python项目中不要出现与第三库同名的文件,否则导入的时候根据优先级它会先导入你所创建的文件。


具体操作见如下代码和其中注释:

import pymysql# 第一步,连接数据库,类似于指令里面的  mysql -uroot -p# mysql -h地址 -uroot -p'''
连接数据库需要用到的参数
主机:host
端口:port
用户名:user
密码:password
指定数据库:db
指定字符集:charset
'''db = pymysql.connect(host='localhost', port=3306, user='root', password='root', db='ghope', charset='utf8')# 连接成功之后,得到一个对象# print(db)# 首先根据db得到游标,游标就是执行sql语句用到的东西# cursor = db.cursor()# 给cursor添加一个参数,让其的到数据是一个字典cursor = db.cursor(cursor=pymysql.cursors.DictCursor)# 准备sql语句,执行sql语句sql = 'select * from star'# 返回结果rows是受影响的行数rows = cursor.execute(sql)# print(rows)# 通过cursor的方法得到数据# 返回一个元组,元组里面每个元素的值对应的就是数据表中每个字段对应的值# 获取内容的时候,里面有个迭代器在记录你的位置# print(cursor.fetchone())# print(cursor.fetchone())# print(cursor.fetchone())# print(cursor.fetchone())# print(cursor.fetchmany(5))# print(cursor.fetchmany(5))# 元组里面套元组# print(cursor.fetchall())# 打印得到所有的用户名ret = cursor.fetchall()for obj in ret:
    print('我叫%s,我来自%s,我有%s¥' % (obj['name'], obj['province'], obj['money']))# print(ret)# 遍历每一个元组# for tp in ret:#     print(tp[1])# 最后呀,要记得关闭cursor.close()
db.close()

webp

上述代码运行结果


增加代码健壮性

import pymysql

db = pymysql.connect(host='localhost', port=3306, user='root', passwd='root', db='ghope', charset='utf8')# print(db)cursor = db.cursor()
sql = 'select * from start'# 查询语句,通过try-except,让代码更加健壮try:
    ret = cursor.execute(sql)
    print(cursor.fetchall())except Exception as e:
    print(e)finally:
    cursor.close()
    db.close()

增加数据安全性

import pymysql

db = pymysql.connect(host='localhost', port=3306, user='root', passwd='root', db='ghope', charset='utf8')
cursor = db.cursor()'''
# 准备sql语句
obj = {'name': '李云龙', 'money': '20', 'province': '河南', 'age': 36, 'sex': '男'}
# 注意,这里的引号需要加
sql = 'insert into star(name, money, province, age, sex) values("%s", "%s", "%s", "%s", "%s")' % (obj['name'], obj['money'], obj['province'], obj['age'], obj['sex'])
'''# id = 8# sql = 'delete from star where id=%s' % idsql = 'update star set name="马德华" where id=12'# 注意,没有添加进去,是因为没有提交,需要提交才能成功try:
    cursor.execute(sql)    # 提交,写入磁盘
    db.commit()
except Exception as e:    print(e)    # 回滚到最初始的状态
    db.rollback()finally:
    cursor.close()
    db.close()

自己拟写一个基本的数据库操作类,当然之后使用的还是大神们写的那些比较高级的库类之类的。

import pymysqlclass MyMysql(object):
    def __init__(self, host, port, user, password, db, charset):        self.host = host        self.port = port        self.user = user        self.password = password        self.dbname = db        self.charset = charset        # 链接数据库
        self.connect()    
    def connect(self):        # 链接数据库和获取游标
        self.db = pymysql.connect(host=self.host, port=self.port, user=self.user, password=self.password, db=self.dbname, charset=self.charset)        self.cursor = self.db.cursor()    
    def run(self, sql):
        ret = None        try:
            ret = self.cursor.execute(sql)            self.db.commit()
        except Exception as e:
            self.db.rollback()        finally:
            self.close()        return ret            
    def close(self):        self.cursor.close()        self.db.close()    
    def insert(self, sql):        return self.run(sql)    
    def update(self, sql):        return self.run(sql)    
    def delete(self, sql):        return self.run(sql)    
    def read_one(self, sql):
        ret = None        try:
            self.cursor.execute(sql)            # 获取得到数据
            ret = self.cursor.fetchone()
        except Exception as e:
            print('查询失败')        finally:
            self.close()        return ret    
    def read_many(self, sql):
        ret = None        try:
            self.cursor.execute(sql)            # 获取得到数据
            ret = self.cursor.fetchall()
        except Exception as e:
            print('查询失败')        finally:
            self.close()        return ret



作者:GHope
链接:https://www.jianshu.com/p/6ad9c8cf1624


点击查看更多内容
1人点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消