标签:sql语句 clip port 执行 code strong 方法 分享 insert
import pymysql if __name__ == ‘__main__‘: #创建MYSQL连接 conn = pymysql.Connect(host = ‘127.0.0.1‘,port = 3306,user = ‘root‘,passwd = ‘root‘,db = ‘databasetest‘,charset = ‘utf8‘) #创建游标:用于 Python 和 Mysql 之间的通信,即:用于执行 SQL 语句。 cursor = conn.cursor() try: #增加数据库 sql = "INSERT INTO userdata VALUES (1,‘lbg‘),(2,‘zgj‘),(3,‘ldt‘)" cursor.execute(sql) #删除数据库 sql2 = "DELETE FROM userdata WHERE id=3" cursor.execute(sql2) #更新数据库 sql3 = "UPDATE userdata SET username=‘wjz‘ WHERE id=2" cursor.execute(sql3) #查询数据库 sql4 = "SELECT * FROM userdata" num = cursor.execute(sql4) print("the number of the userdata: %d" % num) #fetchall返回一个元组,其中包含所有查询的结果。 for row in cursor.fetchall(): print(" ID: "+str(row[0])+" name: "+row[1]) except Exception as reason: #SQL事物回滚:将事务中对数据库的所有已经完成的操作全部撤销,回滚到事务开始时的状态 conn.rollback() print(‘事务处理失败‘, reason) else: #SQL事物确认:只有事物确认之后,数据库操作才会生效 conn.commit() print(‘事务处理成功‘,cursor.rowcount) finally: #关闭连接和游标 cursor.close() conn.close()
import pymysql import sys class TransferMoney: def __init__(self,conn): self.conn = conn def transfer(self,id_out,id_in,money): try: self.HasIdAccount(id_out) self.HasIdAccount(id_in) self.OutIdHasEnoughMoney(id_out,money) self.SubMoney(id_out,money) self.AddMoney(id_in,money) conn.commit() except Exception as e: self.conn.rollback() raise e def HasIdAccount(self,userid): cursor = self.conn.cursor() try: sql = "select * from goods_change where id = %s" % userid cursor.execute(sql) res = cursor.fetchall() if len(res) != 1: raise Exception("id %s is not exist" % userid) print("Has id " + str(userid)) finally: cursor.close() def OutIdHasEnoughMoney(self,userid,change_money): cursor = self.conn.cursor() try: sql = "select money from goods_change where id = %s" % userid cursor.execute(sql) if int(cursor.fetchone()[0]) < int(change_money): raise Exception("id %s has not enough money" % userid) print("id " + str(userid) + " has enough money") finally: cursor.close() def SubMoney(self,userid,change_money): cursor = self.conn.cursor() try: sql = "update goods_change set money=money-%s where id=%s" % (change_money,userid) cursor.execute(sql) if cursor.rowcount != 1: raise Exception("id %s is not exist" % userid) print("id " + str(userid) + " sub " + str(change_money) + " RMB") finally: cursor.close() def AddMoney(self,userid,change_money): cursor = self.conn.cursor() try: sql = "update goods_change set money=money+%s where id=%s" % (change_money,userid) cursor.execute(sql) if cursor.rowcount != 1: raise Exception("id %s is not exist" % userid) print("id " + str(userid) + " add " + str(change_money) + " RMB") finally: cursor.close() if __name__ == ‘__main__‘: conn = pymysql.Connect(host=‘127.0.0.1‘,port=3306,user=‘root‘,passwd=‘root‘,db=‘goods‘,charset=‘utf8‘) id_out = sys.argv[1] id_in = sys.argv[2] money = sys.argv[3] trans = TransferMoney(conn) try: trans.transfer(id_out,id_in,money) except Exception as reason: print(‘事务处理失败:‘, reason) finally: conn.close()
标签:sql语句 clip port 执行 code strong 方法 分享 insert
原文地址:https://www.cnblogs.com/ladawn/p/8909082.html