"""
Test connection to MySQL
using mysql-client conn = MySQLdb.connect(host,port,user,passwd,db,charset)
cursor = conn.cursor() cursor.execute(sql, (arg1,arg2,arg3...))
conn.commit()
conn.rollback() cursor.description # (col1,...),(col2,....),(col3,...),(col4,...)
cursor.rowcount columns = map(lambda e:e[0], cursor.description)
columns = tuple(columns) # (col1,col2,col3...)
cur_record = cursor.fetchone() # (key1,key2,key3...) cur_result = dict(zip(columns,cur_record)) # {col1:key1, col2:key2, col3:key3....} cursor.close() # no more operation is valid if cursor closed
conn.close() # close connection to MySQL database """
import MySQLdb
import datetime class MySQLHandler():
  def __init__(self):
    self.conn = None
    self.cursor = None
    self.cur_record = ()
    self.host = ''
    self.port = 0
    self.user = ''
    self.passwd = ''
    self.db = ''
    self.charset = 'utf8' def connect(self, host, port, user, passwd, db, charset):
  self.host = host
  self.port = port
  self.user = user
  self.passwd = passwd
  self.db = db
  self.charset = charset   try:
    self.conn = MySQLdb.connect(
    host = self.host,
    port = self.port,
    user = self.user,
    passwd = self.passwd,
    db = self.db,
    charset = self.charset
  )
  self.cursor = self.conn.cursor()
  except MySQLdb.Error as e:
    print("Conn MySQL Error, %d: %s" %(e.args[0], e.args[1]) ) def execute_one(self, sql, args):
  self.cursor.execute(sql, args) def insert_one(self,sql,args):
  try:
    # 如果多条插入语句都没异常,则直接通过commit()将数据写入db
    # 如果任意一条语句产生异常,则进入except处理(还没运行try中的commit)
    # except中可以全部不提交,或者提交没触发异常的sql语句
    # 全部不提交, 则except中写入:self.conn.commit()
    # 部分提交(没触发异常的语句结果,则except中写入:self.conn.commit()     self.cursor.execute(sql,args)
    # write changes to db, if no exception
    self.conn.commit()
  except :
    # drop data, if any exception happens, no data saved to db
    self.conn.rollback() def delete_one(self,sql,args):
  try:
  # 如果多条delete语句都没异常,则直接通过commit()将数据写入db
  # 如果任意一条语句产生异常,则进入except处理(还没运行try中的commit)
  # except中可以全部不提交,或者提交没触发异常的sql语句
  # 全部不提交, 则except中写入:self.conn.commit()
  # 部分提交(没触发异常的语句结果,则except中写入:self.conn.commit()     self.cursor.execute(sql,args)
    # write changes to db, if no exception
    self.conn.commit()
  except :
    # drop data, if any exception happens, no data saved to db
    self.conn.rollback() def show(self):
  # show row count
  print("Row Count: " + str(self.cursor.rowcount))   # get table column name
  columns = map(lambda e: e[0], self.cursor.description)
  columns = tuple(columns)   # show all results
  self.cur_record = self.cursor.fetchone()
  while self.cur_record != None:
    print( dict(zip(columns, self.cur_record)) )
    self.cur_record = self.cursor.fetchone() def close(self):
  # close connection to mysql
  self.cursor.close()
  self.conn.close()   # reset attributes
  self.conn = None
  self.cursor = None
  self.cur_record = ()
  self.host = ''
  self.port = 0
  self.user = ''
  self.passwd = ''
  self.db = ''
  self.charset = 'utf8' # Test MySQLHandler, create connection
mysql_handler = MySQLHandler()
mysql_handler.connect('localhost', 3306, 'root', 'weilan0415', 'news', 'utf8') # prepare sql to execute
# sql = 'select * from employees where salary > %s limit %s, %s'
# args = (2500, 0, 10) # run 1 sql operation
# mysql_handler.execute_one(sql, args) # insert one record into mysql
sql = 'insert into news (title, image, content, types, create_at, is_valid) ' \
'value (%s, %s, %s, %s, %s, %s);'
cur_time = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")
mysql_handler.insert_one(sql, ("new222", "D:\\Durian.jpg", "新闻内容222", "美食", cur_time, 1) ) # delete
sql = 'delete from news where id between 6 and 10'
mysql_handler.delete_one(sql, ()) # query
sql = 'select * from news'
mysql_handler.execute_one(sql, ()) # show result
mysql_handler.show() # close connection
mysql_handler.close()

12_Python操作MySQL(basic)的更多相关文章

  1. ASP.NET Core 1.0 使用 Dapper 操作 MySql(包含事务)

    操作 MySql 数据库使用MySql.Data程序包(MySql 开发,其他第三方可能会有些问题). project.json 代码: { "version": "1. ...

  2. Python(九) Python 操作 MySQL 之 pysql 与 SQLAchemy

    本文针对 Python 操作 MySQL 主要使用的两种方式讲解: 原生模块 pymsql ORM框架 SQLAchemy 本章内容: pymsql 执行 sql 增\删\改\查 语句 pymsql ...

  3. EF操作MySql

    EF的CodeFrist操作MySql的提前准备: 1.安装两个包:MySql.Data和MySql.Data.Entity,在VS中程序包管理器中添加2个包.(备注需要的VS2015,并且EF6支持 ...

  4. .NET Core 使用Dapper 操作MySQL

    MySQL官方驱动:http://www.cnblogs.com/linezero/p/5806814.html .NET Core 使用Dapper 操作MySQL 数据库, .NET Core 使 ...

  5. asp.net core 1.1 升级后,操作mysql出错的解决办法。

    遇到问题 core的版本从1.0升级到1.1,操作mysql数据库,查询数据时遇到MissingMethodException问题,更新.插入操作没有问题. 如果你也遇到这个问题,请参照以下步骤进行升 ...

  6. 练习:python 操作Mysql 实现登录验证 用户权限管理

    python 操作Mysql 实现登录验证 用户权限管理

  7. Python操作MySQL

    本篇对于Python操作MySQL主要使用两种方式: 原生模块 pymsql ORM框架 SQLAchemy pymsql pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb ...

  8. Python中操作mysql的pymysql模块详解

    Python中操作mysql的pymysql模块详解 前言 pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎相同.但目前pymysql支持python3.x而后者不支持 ...

  9. java分享第十七天-03(封装操作mysql类)

     JAVA操作mysql所需jar包:mysql-connector-java.jar代码: import java.sql.*; import java.util.ArrayList; import ...

随机推荐

  1. OC导航栏自定义返回按钮

    [iOS]让我们一次性解决导航栏的所有问题 在默认情况下,导航栏返回按钮长这个样子   导航栏默认返回按钮 导航栏左上角的返回按钮,其文本默认为上一个ViewController的标题,如果上一个Vi ...

  2. 10 jmeter之动态关联

    jmeter中关联是通过之前请求的后置处理器实现的,具体有两种方式:XPath Extractor(一般xml的时候用的多)和正则表达式提取器. 以webtours登录为例进行演示login.jmx ...

  3. 空类指针为什么可以调用类的成员函数 以及 A(){}和A();

    1. 代码及问题 #include <iostream> using namespace std; class A { public: A() {} //A *p = new A()时:此 ...

  4. python中关于不执行if __name__ == '__main__':测试模块的解决

    1.新建测试脚本文件: 2.编辑测试脚本 import unittest import requests import json import HTMLTestRunner ur1 = 'http:/ ...

  5. 机器学习理论基础学习18---高斯过程回归(GPR)

    一.高斯(分布)过程(随机过程)是什么? 一维高斯分布 多维高斯分布 无限维高斯分布   高斯网络 高斯过程 简单的说,就是一系列关于连续域(时间或空间)的随机变量的联合,而且针对每一个时间或是空间点 ...

  6. Lintcode: Heapify && Summary: Heap

    Given an integer array, heapify it into a min-heap array. For a heap array A, A[0] is the root of he ...

  7. Listener—监听器

    什么是监听器? 监听器是Web应用程序事件模型的一部分 监听器的作用? 1:Web应用中某些状态发生改变的时候会产生相应的事件: a)servletContext.HttpSession.Servle ...

  8. python+Django框架运用(四)

    Django后台管理 基本配置 默认登录地址:http://127.0.0.1:8000/admin 创建后台管理员: python3  ./manage.py  createsuperuser # ...

  9. HTML 和 JavaScript 实现飘花的效果

    HTML 和 JavaScript 实现飘花的效果,也不算花,就是有悬浮物飘下来,和下雪似的. 也是不需要图片和其他的 js 脚本做辅助,其实已经全写在 HTML 文件中了. <html> ...

  10. ORM 关系对象映射 基础知识点

    优点: 1.ORM使我们通用的数据库变得更加的简单便捷. 2.可避免新手程序员写sql语句带来的性能问题. 1. 创建单表 2. 创建关键表 1). 一对一 2). 一对多 3). 多对多 创建表的语 ...