検索
ホームページバックエンド開発Python チュートリアルPython サーバー プログラミング: PyMySQL を使用した MySQL データベースとの対話

Python は、さまざまな種類のアプリケーションの開発に使用できる豊富なライブラリとフレームワークを備えた人気の高水準プログラミング言語です。サーバー プログラミングの分野では、Python は Web アプリケーションの開発だけでなく、さまざまなデータベースとの対話にも使用できます。

この記事では、Python を使用して MySQL データベースと対話する方法を紹介します。 MySQL と対話するための Python のライブラリとして PyMySQL を使用します。

1. PyMySQL ライブラリをインストールする

PyMySQL ライブラリを使用する前に、まずインストールする必要があります。ターミナルまたはコマンド プロンプトを開き、次のコマンドを入力してインストールします:

pip install PyMySQL

2. MySQL データベースに接続します

MySQL データベースに接続するには、ホスト名とポートを知る必要があります。 MySQL サーバーの番号、ユーザー名、パスワード。

次の Python コードを使用して MySQL データベースに接続できます:

import pymysql

# 打开数据库连接
db = pymysql.connect(host='localhost', port=3306, user='root', password='', database='test')

# 关闭数据库连接
db.close()

このコードでは、pymysql# の connect() を使用しています。 ## library MySQL データベースに接続する関数。この関数のパラメータには、ホスト名、ポート番号、ユーザー名、パスワードなどの情報が含まれます。

さらに、接続するデータベースの名前も指定します。これは、

database パラメーターを通じて渡されます。以下のコードでは、この接続を引き続き使用します。

3. テーブルの作成

MySQL データベースを操作する前に、テーブルを作成する必要があります。次の Python コードを使用して、MySQL データベースに

users という名前のテーブルを作成できます。

import pymysql

# 打开数据库连接
db = pymysql.connect(host='localhost', port=3306, user='root', password='', database='test')

# 创建表
cursor = db.cursor()
cursor.execute('DROP TABLE IF EXISTS users')
sql = '''CREATE TABLE users (
         id INT(11) NOT NULL AUTO_INCREMENT,
         name VARCHAR(20) NOT NULL,
         email VARCHAR(30) NOT NULL,
         password VARCHAR(30) NOT NULL,
         PRIMARY KEY (id))'''
cursor.execute(sql)

# 关闭数据库连接
db.close()

このコードでは、

users table という名前のテーブルを定義し、4 つのテーブルを定義します。列: idnameemail、および password。このうち、id は主キーであり、INT データ型を使用し、nameemailVARCHAR を使用して保存されます。 データ型 文字列 password も、VARCHAR データ型を使用して保存された文字列です。テーブル作成プロセスでは、MySQL SQL ステートメントを使用します。 users テーブルにも自動インクリメント列が設定されており、自動的にインクリメントされることに注意してください。

4. データの挿入

users テーブルを作成したので、テーブルへのデータの挿入を開始できます。次の Python コードを使用して、このテーブルにデータを挿入できます:

import pymysql

# 打开数据库连接
db = pymysql.connect(host='localhost', port=3306, user='root', password='', database='test')

# 插入数据
cursor = db.cursor()
sql = "INSERT INTO users(name, email, password) VALUES (%s, %s, %s)"
values = [('Alice', 'alice@email.com', '123456'),
          ('Bob', 'bob@email.com', '789012'),
          ('Charlie', 'charlie@email.com', '345678')]
cursor.executemany(sql, values)
db.commit()

# 关闭数据库连接
db.close()

このコードでは、まず

executemany() 関数 を使用して複数のデータを users に挿入します。テーブル。この関数の最初のパラメータは実行する SQL ステートメントを指定し、2 番目のパラメータは挿入するデータを含むタプルまたはリストです。挿入される実際の値を表すためにプレースホルダー %s を使用したことに注意してください。

executemany() 関数を呼び出した後、commit() メソッドを呼び出してデータをデータベースに保存する必要があります。

5. データのクエリ

users テーブルからデータを取得するには、次の Python コードを使用できます:

import pymysql

# 打开数据库连接
db = pymysql.connect(host='localhost', port=3306, user='root', password='', database='test')

# 查询数据
cursor = db.cursor()
sql = "SELECT * FROM users"
cursor.execute(sql)
results = cursor.fetchall()
for row in results:
    id = row[0]
    name = row[1]
    email = row[2]
    password = row[3]
    print("{} - {} - {} - {}".format(id, name, email, password))

# 关闭数据库连接
db.close()

このコードでは、

SELECT ステートメントを使用して、users テーブルからすべての行を取得します。次に、fetchall() メソッドを使用して取得したすべての行を取得し、ループを使用して各行をタプルとして処理します。最後に、各行の列値に基づいて出力を印刷します。

6.データの更新

users テーブルのデータを更新するには、次の Python コードを使用できます:

import pymysql

# 打开数据库连接
db = pymysql.connect(host='localhost', port=3306, user='root', password='', database='test')

# 更新数据
cursor = db.cursor()
sql = "UPDATE users SET password = %s WHERE name = %s"
values = ('abcdef', 'Alice')
cursor.execute(sql, values)
db.commit()

# 关闭数据库连接
db.close()

このコードでは、

UPDATE ステートメントを使用して、Alice という名前のユーザーのパスワードを abcdef に更新します。このコードでは、パラメーターを含む SQL ステートメントを使用します。%s はプレースホルダーです。また、更新される実際の値をタプルにラップし、それを execute() 関数に渡します。

7. データの削除

users テーブルからデータを削除するには、次の Python コードを使用できます:

import pymysql

# 打开数据库连接
db = pymysql.connect(host='localhost', port=3306, user='root', password='', database='test')

# 删除数据
cursor = db.cursor()
sql = "DELETE FROM users WHERE email = %s"
value = ('bob@email.com',)
cursor.execute(sql, value)
db.commit()

# 关闭数据库连接
db.close()

このコードでは、

DELETE ステートメントを使用して、メール アドレス bob@email.com のユーザーを削除します。

概要

この記事では、Python を使用して MySQL データベースと対話する方法と、Python と MySQL の間のブリッジとして

pymysql ライブラリを使用する方法を紹介しました。 MySQL データベースへの接続、テーブルの作成、データの挿入、データの更新、およびデータの削除の方法を学びました。これらは、Web アプリケーションの開発時によく関係する一般的なタスクです。これらのスキルを習得すると、Python を使用して強力なサーバー アプリケーションを構築したり、さまざまなデータベースと対話したりできるようになります。

以上がPython サーバー プログラミング: PyMySQL を使用した MySQL データベースとの対話の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Pythonの主な目的:柔軟性と使いやすさPythonの主な目的:柔軟性と使いやすさApr 17, 2025 am 12:14 AM

Pythonの柔軟性は、マルチパラダイムサポートと動的タイプシステムに反映されていますが、使いやすさはシンプルな構文とリッチ標準ライブラリに由来しています。 1。柔軟性:オブジェクト指向、機能的および手続き的プログラミングをサポートし、動的タイプシステムは開発効率を向上させます。 2。使いやすさ:文法は自然言語に近く、標準的なライブラリは幅広い機能をカバーし、開発プロセスを簡素化します。

Python:汎用性の高いプログラミングの力Python:汎用性の高いプログラミングの力Apr 17, 2025 am 12:09 AM

Pythonは、初心者から上級開発者までのすべてのニーズに適した、そのシンプルさとパワーに非常に好まれています。その汎用性は、次のことに反映されています。1)学習と使用が簡単、シンプルな構文。 2)Numpy、Pandasなどの豊富なライブラリとフレームワーク。 3)さまざまなオペレーティングシステムで実行できるクロスプラットフォームサポート。 4)作業効率を向上させるためのスクリプトおよび自動化タスクに適しています。

1日2時間でPythonを学ぶ:実用的なガイド1日2時間でPythonを学ぶ:実用的なガイドApr 17, 2025 am 12:05 AM

はい、1日2時間でPythonを学びます。 1.合理的な学習計画を作成します。2。適切な学習リソースを選択します。3。実践を通じて学んだ知識を統合します。これらの手順は、短時間でPythonをマスターするのに役立ちます。

Python vs. C:開発者の長所と短所Python vs. C:開発者の長所と短所Apr 17, 2025 am 12:04 AM

Pythonは迅速な開発とデータ処理に適していますが、Cは高性能および基礎となる制御に適しています。 1)Pythonは、簡潔な構文を備えた使いやすく、データサイエンスやWeb開発に適しています。 2)Cは高性能で正確な制御を持ち、ゲームやシステムのプログラミングでよく使用されます。

Python:時間のコミットメントと学習ペースPython:時間のコミットメントと学習ペースApr 17, 2025 am 12:03 AM

Pythonを学ぶのに必要な時間は、人によって異なり、主に以前のプログラミングの経験、学習の動機付け、学習リソースと方法、学習リズムの影響を受けます。現実的な学習目標を設定し、実用的なプロジェクトを通じて最善を尽くします。

Python:自動化、スクリプト、およびタスク管理Python:自動化、スクリプト、およびタスク管理Apr 16, 2025 am 12:14 AM

Pythonは、自動化、スクリプト、およびタスク管理に優れています。 1)自動化:OSやShutilなどの標準ライブラリを介してファイルバックアップが実現されます。 2)スクリプトの書き込み:Psutilライブラリを使用してシステムリソースを監視します。 3)タスク管理:スケジュールライブラリを使用してタスクをスケジュールします。 Pythonの使いやすさと豊富なライブラリサポートにより、これらの分野で優先ツールになります。

Pythonと時間:勉強時間を最大限に活用するPythonと時間:勉強時間を最大限に活用するApr 14, 2025 am 12:02 AM

限られた時間でPythonの学習効率を最大化するには、PythonのDateTime、時間、およびスケジュールモジュールを使用できます。 1. DateTimeモジュールは、学習時間を記録および計画するために使用されます。 2。時間モジュールは、勉強と休息の時間を設定するのに役立ちます。 3.スケジュールモジュールは、毎週の学習タスクを自動的に配置します。

Python:ゲーム、GUIなどPython:ゲーム、GUIなどApr 13, 2025 am 12:14 AM

PythonはゲームとGUI開発に優れています。 1)ゲーム開発は、2Dゲームの作成に適した図面、オーディオ、その他の機能を提供し、Pygameを使用します。 2)GUI開発は、TKINTERまたはPYQTを選択できます。 TKINTERはシンプルで使いやすく、PYQTは豊富な機能を備えており、専門能力開発に適しています。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境