import pymysql # 1.连接mysql ip 端口号 密码 账号 数据库 charset='utf8' # 2.建立游标 # 3.执行sql # 4.获取结果 # 5.关闭连接,关闭游标
# charset 必须填写utf8 port一定要写int类型 conn = pymysql.connect(host='192.168.1.20', port=3306, user='root', passwd='123456', db='test', charset='utf8') # cur = conn.cursor() # 建立游标,游标认为是仓库管理员 cur = conn.cursor(cursor=pymysql.cursors.DictCursor) # 需要指定游标的类型,字典类型 # cur.execute('select * from student;') # 执行sql语句 cur.execute('select * from student;') # update delete insert 需要提交才会生效 # cur.execute('insert into student (username, password) values (%s,%s)', ('wangsilei3', '123456')) # conn.commit() # 提交 # res = cur.fetchall() # 获取sql语句执行结果,他把结果放到一个元组里面,每一条数据也是一个元组 res = cur.fetchone() # 只获取一条结果,它的结果是一个一维的元组 print(res)
# cur.scroll(0, mode='absolute') # 移动游标 # cur.scroll(1, mode='relative') # 相对当前位置移动 -1往前移动 # cur.scroll(2, mode='absolute') # 相对绝对位置移动 # res = cur.fetchone() # 获取第二条数据 # print(res) cur.close() # 关闭游标 conn.close() # 关闭连接 封装操作数据库方法
import pymysql def op_mysql(host, user, password, db, sql, port=3306, charset='uft8'): conn = pymysql.connect(host=host, user=user, password=password, db=db, port=port, charset=charset) cur = conn.cursor(cursor=pymysql.cursors.DictCursor) cur.execute(sql) sql_start = sql[:6].upper() # 取sql前六个字符串,判断他是什么类型的sql语句 if sql_start == 'SELECT': res = cur.fetchall() else: conn.commit() res = 'OK' cur.close() conn.close() return res # 别人导入该py文件时,下面代码不会被执行 # 一般自己测试的时候写 if __name__ == '__main__': sql1 = 'select * from bt_stu limit 5' res_sql = op_mysql( host='211.149.218.16', user='jxz', password='123456', # port这里一定要写int类型 port=3306, db='jxz', charset='utf8', sql=sql1) print(res_sql)