Heim >Backend-Entwicklung >Python-Tutorial >Python-Datenbankoperationen
Installieren Sie MySQL-Python unter Windows
Download-Adresse: https://pypi.python.org/pypi/MySQL-python/1.2.5 Installieren Sie es einfach im System.
Installieren Sie MySQL-Python unter Linux, um eine Verbindung zu MySQL herzustellen:
Download-Adresse: https://pypi.python.org/pypi/MySQL-python/
Geben Sie nach dem Entpacken das Verzeichnis ein und führen Sie python setup.py install aus
Häufige Probleme, die während des Installationsvorgangs auftreten:
1 mysql_config kann nicht gefunden werden. Dies liegt normalerweise daran, dass mysql mit dem lnmp-One-Click-Installationspaket installiert wird. Der Pfad lautet
. Lösung: Suchen Sie nach mysql_config, um den Speicherort der Datei mysql_config zu finden -s, um einen Softlink zu erstellen.
2. Wenn Ubuntu meldet, dass „x86_64-linux-gnu-gcc“ fehlt, müssen Sie das Python-Dev-Paket installieren:
Lösung: sudo apt -get install python -dev -y
3. Der Befehl „gcc“ ist mit Exit-Status 1 fehlgeschlagen.
wird unter CentOS aufgefordert. Lösung: yum install gcc python-devel -y
Geben Sie nach Abschluss der Installation Python ein und führen Sie import MySQLdb aus, um zu sehen, ob der Import erfolgreich ist.
Ergänzung:
Als ich unter Ubuntu arbeitete, stellte ich fest, dass ich keine Verbindung zur Datenbank herstellen konnte. ss -lnt stellte fest, dass MySQL nur den 3306-Port an der Loopback-Adresse abhörte muss geändert werden.
Ändern Sie Ubuntus MySQL und ändern Sie seinen Überwachungsport 127.0.0.1:3306, um externe Verbindungen zuzulassen:
Bearbeiten Sie /etc/mysql/my.cnf (die Konfigurationsparameter befinden sich möglicherweise in anderen Dateien in diesem Verzeichnis. Schauen Sie genau hin)
Ändern Sie bind-address = 0.0.0.0, um den Zugriff von jeder IP aus zu ermöglichen.
Führen Sie dann /etc/init.d/mysql restart aus, um den MySQLserver-Dienst neu zu starten
# Das Folgende ist ein Beispiel für den Betrieb der Datenbank durch Python:
#!/usr/bin/env python # -*- coding:utf8 -*- import MySQLdb conn = MySQLdb.connect( host = '192.168.2.14', port = 3306, user = 'root', passwd = '123456', db = 'demo', ) # 操作数据库首先需要创建游标 cur = conn.cursor() # 通过游标cur操作execute()方法可以写入纯sql语句,如下: # 创建数据表 # cur.execute("create table teacher (id int(5),name varchar(20),class varchar(20),age varchar(10))") # 插入数据 # cur.execute("insert into teacher values(23,'zhangsan','science',15)") # 修改数据 # cur.execute("update teacher set id=100 where name='zhangsan'") # 删除数据 # cur.execute("delete from teacher where id=100") #插入一条数据【也可以用像下面这种写法】 sqli="insert into teacher values(%s,%s,%s,%s)" cur.execute(sqli, (23,'zhangsan','science',15)) # 使用executemany一次性向数据表中插入多条值,返回值为受影响的行数。 sqli="insert into teacher values(%s,%s,%s,%s)" cur.executemany(sqli,[ (11,'wangwu','art',23), (8,'john','math',22), (3,'Tom','physical',25), ]) # 最后关闭游标,执行提交操作,并关闭数据库连接 cur.close() conn.commit() conn.close()
Daten abrufen und ausgeben
#!/usr/bin/env python # -*- coding:utf8 -*- import MySQLdb conn = MySQLdb.connect( host = '192.168.2.14', port = 3306, user = 'root', passwd = '123456', db = 'demo', ) cur = conn.cursor() # 获得表中有多少条数据 aa = cur.execute("select * from teacher") cur.fetchone() # fetchone()方法可以帮我们获得表中的数据,但是每执行一次输出一行满足条件的值 cur.fetchone() ...... cur.scroll(0,'absolute')# 这样能将游标定位到表中的第一条数据 info = cur.fetchmany(aa) for i in info: print i cur.close() conn.commit() conn.close()
Der Herausgeber wird Ihnen so viel über die Datenbankoperationen von Python vorstellen. Ich hoffe, es wird Ihnen hilfreich sein!
Weitere Artikel zu Pythons Datenbankoperationen finden Sie auf der chinesischen PHP-Website!