ホームページ >バックエンド開発 >Python チュートリアル >Pythonでmysqlデータベースを操作する

Pythonでmysqlデータベースを操作する

高洛峰
高洛峰オリジナル
2017-03-08 09:35:481102ブラウズ

1. 基本的なデータベース操作

1. データベースへの中国語の書き込みを許可したい場合は、データベースの作成時に次のコマンドを使用できます

CREATE database zcl charset utf8;CREATE database zcl charset utf8;

2. 查看students表结构

desc students;

3. 查看创建students表结构的语句

show create table students;

4. 删除数据库

drop database zcl;

5. 创建一个新的字段

alter table students add column nal char(64); 

PS: 本人是很讨厌上面这种“简单解释+代码”的博客。其实我当时在mysql终端写了很多的实例,不过因为当时电脑运行一个看视频的软件,导致我无法Ctrl+C/V。现在懒了哈哈~~

二、python连接数据库

python3不再支持mysqldb。其替代模块是PyMySQL。本文的例子是在python3.4环境。

1. 安装pymysql模块

pip3 install pymysql

2. Students テーブルの構造を表示します

desc students;3. Students テーブルの構造を作成するステートメントを表示します

show create table students;

4データベースを削除します

drop database zcl;

5. 新しいフィールドを作成します

alter table students add columns nal char(64);

追伸:この「簡単な説明」+Code」ブログは嫌いです。実は当時、mysql ターミナルでサンプルをたくさん書いたのですが、当時のコンピュータでは動画視聴ソフトが動作していたため、Ctrl+C/V が使えませんでした。もうめんどくさいです笑~~

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

python3 は mysqldb をサポートしなくなりました。その代替モジュールは PyMySQL です。この記事の例は python3.4 環境でのものです。

1. pymysql モジュールをインストールします

pip3 install pymysql

2. データベースに接続し、データ インスタンスを挿入します

import pymysql
#生成实例,连接数据库zcl
conn = pymysql.connect(host='127.0.0.1', user='root', passwd='root', db='zcl')
#生成游标,当前实例所处状态
cur = conn.cursor()
#插入数据
reCount = cur.execute('insert into students(name, sex, age, tel, nal) values(%s, %s, %s, %s, %s)',('Jack','man',25,1351234,"CN"))
reCount = cur.execute('insert into students(name, sex, age, tel, nal) values(%s, %s, %s, %s, %s)',('Mary','female',18,1341234,"USA"))
conn.commit() #实例提交命令 
cur.close()
conn.close()
print(reCount)
を表示します。結果:
mysql> select* from students;
+----+------+-----+-----+-------------+------+
| id | name | sex | age | tel | nal |
+----+------+-----+-----+-------------+------+
| 1 | zcl | man | 22 | 15622341234 | NULL |
| 2 | alex | man | 30 | 15622341235 | NULL |
+----+------+-----+-----+-------------+------+
rows in set

3. データの取得

import pymysql
conn = pymysql.connect(host='127.0.0.1', user='root', passwd='root', db='zcl')
cur = conn.cursor()
reCount = cur.execute('select* from students')
res = cur.fetchone() #获取一条数据
res2 = cur.fetchmany(3) #获取3条数据
res3 = cur.fetchall() #获取所有(元组格式)
print(res)
print(res2)
print(res3)
conn.commit()
cur.close()
conn.close()

出力:

(1, 'zcl', 'man', 22, '15622341234', None)
((2, 'alex', 'man', 30, '15622341235', None), (5, 'Jack', 'man', 25, '1351234', 'CN'), (6, 'Mary', 'female', 18, '1341234', 'USA'))
()

3、トランザクションのロールバック

データが書き込まれる前にロールバックが実行されますしたがって、トランザクションのロールバック conn.rollback() は、インスタンスがコマンド conn.commit() をコミットする前に行う必要があります。

データが送信されない限り、ロールバックできますが、ID はロールバック後に自動的にインクリメントされます。

次の例を参照してください:

3 つのデータを挿入します (トランザクションのロールバックに注意してください):

import pymysql
#连接数据库zcl
conn=pymysql.connect(host='127.0.0.1', user='root', passwd='root', db='zcl')
#生成游标,当前实例所处状态
cur=conn.cursor()
#插入数据
reCount=cur.execute('insert into students(name, sex, age, tel, nal) values(%s, %s, %s, %s, %s)', ('Jack', 'man', 25, 1351234, "CN"))
reCount=cur.execute('insert into students(name, sex, age, tel, nal) values(%s,%s,%s,%s,%s)', ('Jack2', 'man', 25, 1351234, "CN"))
reCount=cur.execute('insert into students(name, sex, age, tel, nal) values(%s, %s, %s, %s, %s)', ('Mary', 'female', 18, 1341234, "USA"))
conn.rollback() #事务回滚
conn.commit() #实例提交命令 
cur.close()
conn.close()
print(reCount)

コマンドの実行前とコマンドの実行後 (ロールバック操作を含む) (ID に注意してください) number): 未実行 上記のコードを実行した結果は同じです!! トランザクションがロールバックされているため、students テーブルにはデータが追加されません (ロールバック操作を除く)。上記の 11 行目のコードコメントを変更するだけです。

mysql> select* from students;
+----+------+--------+-----+-------------+------+
| id | name | sex | age | tel | nal |
+----+------+--------+-----+-------------+------+
| 1 | zcl | man | 22 | 15622341234 | NULL |
| 2 | alex | man | 30 | 15622341235 | NULL |
| 5 | Jack | man | 25 | 1351234 | CN |
| 6 | Mary | female | 18 | 1341234 | USA |
+----+------+--------+-----+-------------+------+
rows in set

🎜🎜 概要: トランザクションはロールバックされますが、ID はインクリメントされており、ロールバックによってキャンセルされませんが、これはデータの一貫性には影響しません (基礎となる原理~)🎜 🎜🎜🎜🎜4. データのバッチ挿入🎜🎜🎜🎜
mysql> select* from students;
+----+-------+--------+-----+-------------+------+
| id | name | sex | age | tel | nal |
+----+-------+--------+-----+-------------+------+
| 1 | zcl | man | 22 | 15622341234 | NULL |
| 2 | alex | man | 30 | 15622341235 | NULL |
| 5 | Jack | man | 25 | 1351234 | CN |
| 6 | Mary | female | 18 | 1341234 | USA |
| 10 | Jack | man | 25 | 1351234 | CN |
| 11 | Jack2 | man | 25 | 1351234 | CN |
| 12 | Mary | female | 18 | 1341234 | USA |
+----+-------+--------+-----+-------------+------+
rows in set
🎜🎜🎜pycharm 出力: 5🎜🎜mysql ターミナル表示:🎜🎜🎜
import pymysql
#连接数据库zcl
conn = pymysql.connect(host='127.0.0.1', user='root', passwd='root', db='zcl')
#生成游标,当前实例所处状态
cur = conn.cursor()
li = [
 ("cjy","man",18,1562234,"USA"),
 ("cjy2","man",18,1562235,"USA"),
 ("cjy3","man",18,1562235,"USA"),
 ("cjy4","man",18,1562235,"USA"),
 ("cjy5","man",18,1562235,"USA"),
]
#插入数据
reCount = cur.executemany('insert into students(name,sex,age,tel,nal) values(%s,%s,%s,%s,%s)', li)
#conn.rollback() #事务回滚
conn.commit() #实例提交命令
cur.close()
conn.close()
print(reCount)
🎜 Python による mysql データベースの操作に関連するその他の記事については、お支払いください。 PHP中国語サイトに注意! 🎜🎜🎜
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。