python & MySQLdb(two)

来源:https://www.cnblogs.com/kk328/archive/2018/11/03/9901579.html
-Advertisement-
Play Games

實現python封裝# encoding=utf8import MySQLdb#定義類class MysqlHelper(): def __init__(self,host,port,db,user,passwd,charset='utf8'): self.host=host self.port=p... ...


實現python封裝

# encoding=utf8
import MySQLdb

#定義類
class MysqlHelper():
    def __init__(self,host,port,db,user,passwd,charset='utf8'):
       self.host=host
       self.port=port
       self.db=db
       self.user=user
       self.passwd=passwd
       self.charset=charset
     #初始化設置連接

    def connect(self):
        self.conn=MySQLdb.connect(host=self.host,port=self.port,db=self.db,user=self.user,passwd=self.passwd,charset=self.charset)
        self.cursor=self.conn.cursor()
    #進行連接

    def close(self):
        self.cursor.close()
        self.conn.close()
     #關閉連接


    def get_one(self,sql,param=()):
        result=None
        try:
            self.connect()
            self.cursor.execute(sql,param)
            result=self.cursor.fetchone()
            self.close()
        except Exception as e:
            print(e)
        return result
    #查找一行

    def get_all(self,sql,param=()):
        list=()
        try:
            self.connect()
            self.cursor.execute(sql,param)
            list=self.cursor.fetchall()
            self.close()
        except Exception as e:
             print(e)
        return list
    #查找全部數據


    def insert(self,sql,param=()):
        return self.__edit(sql,param)
    #返回插入數據

    def update(self,sql,param):
        return self.__edit(sql,param)
    #返回更改後數據

    def delete(self,sql,param):
        return self.__edit(sql,param)
    #返回刪除數據

    def __edit(self,sql,param):
        count=0
        try:
            self.connect()
            count=self.cursor.execute(sql,param)
            self.conn.commit()
            self.close()
        except Exception as e:
            print(e)
        return count

實現添加操作:

#encoding=utf8
from fengzhaung import *

sql="insert into stu(stu_name,stu_hometown,gender) values(%s,%s,%s)"
stu_name=input("輸入姓名")
stu_hometown=input("請輸入家鄉:")
gender=input("輸入性別,1男,0女:")
param=[stu_name,stu_hometown,bool(gender)]
mysqlh=MysqlHelper('192.168.65.146',3306,'student','root','toor')
count=mysqlh.insert(sql,param)
if count==1:
    print ('ok')
else:
    print('error')

實現查找:

#encoding=utf8
from fengzhaung import *
#id=input("輸入編號")
sql="select * from stu where stu_id=1"
helper=MysqlHelper('192.168.65.146',3306,'student','root','toor')
s=helper.get_one(sql)
print(s)

最後還有一點小問題,怎麼自主輸入進行查找??試了幾種辦法,發現不行。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 圖形 概述 隨著大量的監控數據被採集到Zabbix中,如果用戶可以以可視化的表現形式來查看發生了什麼事情,那麼和僅僅只有數字的表現形式比起來則更加輕鬆。 以下是進行圖形設置的地方。圖形可以一目瞭然地掌握數據的流向並關聯問題,發現某件事情開始,或在某件事情可能變成問題事件時進行報告。 Zabbix為用 ...
  • 下載jdk-版本號.tar.gz 解壓到/usr/local/ vi /etc/profile 最後一行添加如下內容: export JAVA_HOME=/usr/local/jdk-版本號export PATH=$PATH:$JAVA_HOME/binexport CLASSPATH=.:$JAV ...
  • 搭建LNMP環境的時候,在安裝完Nginx後啟動測試Nginx服務時發現報如下錯誤: nginx: [emerg] getpwnam("nginx") failed 這是由於沒有創建nginx用戶導致的,解決辦法就是創建一個nginx用戶 說明:這裡創建的用戶是你安裝Nginx時,預編譯時指定的Ng ...
  • 為了增強無人機與地面站之間的傳輸信號,組裡買了這款WiFi信號接收器,無奈只有Windows和Mac OS版本的驅動程式。後來不知道從哪裡得來的一個偏方可以安裝Ubuntu下的驅動,特此記錄。 內核降級 安裝Ubuntu下的驅動只支持到4.4的內核,一般現在安裝的Ubuntu預設內核都是4.15了, ...
  • 1. 說明 本文檔針對docker swarm操作。 針對的系統是以一個本地的測試系統為例。其中機器信息如下,172.16.1.13作為docker swarm的管理機。 本地測試的機器列表信息: 主機名 模擬的外網 內網IP 要部署模塊 mini01 10.0.0.11 172.16.1.11 t ...
  • 新電腦安裝了Ubuntu 14.04,但是網路連接中只有乙太網而沒有WiFi的選項. 打開System Setting系統設置-Software&Updates軟體&更新-Additional Drivers附加驅動,無法載入出相應的驅動,更換為國內源也無法顯示出相應的驅動. 打開Terminal使 ...
  • 1.背景 互聯網從來就不是一個安全的地方。很多時候我們過分依賴防火牆來解決安全的問題,不幸的是,防火牆是假設“壞人”是來自外部的,而真正具有破壞性的攻擊事件都是往往都是來自於內部的。 近幾年,在thehackernews等網站上總會時不時看到可以看到一些因為數據安全問題被大面積攻擊、勒索的事件。在H ...
  • 原文地址:https://blog.csdn.net/u011583336/article/details/80999043 之前工作中用的資料庫多是ms sqlserver,偶爾用到mysql都是運維配置好 ,今天心血來潮,在本地電腦安裝了一個mysql8.**的版本。建好表測試的時候發現報錯。c ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...