ホームページ >データベース >mysql チュートリアル >pymysql が mysql データベースを操作する方法

pymysql が mysql データベースを操作する方法

PHPz
PHPz転載
2023-05-30 17:40:061741ブラウズ

1.pymysql.connent

使用法: リンクの作成

構文: conn = pymysql.connect(host=‘127.0.0.1&rsquo) ; 、port=ポート番号、user=‘データベースユーザー名’、passwd=‘パスワード’、db=‘データベース名’)

conn = pymysql.connect(host='127.0.0.1', 
                 port=3306, user='root', passwd='@123456', db='db4')

2, conn.cursor()

使用法: カーソルを作成します

cursor = conn.cursor()

カーソルを辞書型に設定します

# 游标设置为字典类型
cursor = conn.cursor("cursor"=pymysql.cursors.DictCursor)

栗子:
sql = "select * from department;"
# 执行sql语句的函数,使用下面函数进行拼接,防止SQL注入
cursor.execute(sql)
# cursor.scroll(1,mode='relative')
result = cursor.fetchone()
print(result)
输出结果:
{'id': 1, 'title': '财务'}

3、cursor.execute()

使用法: SQL ステートメントを実行します

cursor.execute(sql)

4.cursor.executemany()

使用法: SQL ステートメントをバッチで実行します

cursor.executemany(sql,[('销售'), ('经理')])

5,cursor.fetchone()

使用法: SQL 実行選択は、デフォルトでは 1 つの結果のみを取得します。ステートメントを複数回実行すると、順番にデータを取得できます

import  pymysql
# 创建链接,跟socket服务类似
conn = pymysql.connect(host='127.0.0.1', port=3306, 
                 user='root', passwd='@123456', db='db4')
# 创建游标(相当与创建一个拿数据的手)
cursor = conn.cursor()
# 创建要执行的SQL语句
sql = "select * from department;"
# 执行sql语句的函数,使用下面函数进行拼接,防止SQL注入
cursor.execute(sql)
result = cursor.fetchone()
print(result)
result = cursor.fetchone()
print(result)
result = cursor.fetchone()
print(result)
# 关闭链接
cursor.close()
conn.close()
·
输出结果:
(1, '财务')
(2, '公关')
(3, '测试')

6.cursor.scroll()

使用法: 注: データを取得するときは、順番に進みます。cursor.scroll(num, mode) を使用してカーソルを移動できます。例:

  • cursor.scroll(1,mode=‘relative’) # 現在の位置を基準にして移動

  • cursor.scroll(2,mode= ‘absolute’) # 相対絶対位置移動

テーブル構造:

pymysql が mysql データベースを操作する方法

## 栗:

1、
cursor.execute(sql)
result = cursor.fetchone()
print(result)
输出结果:
(1, '财务')
2、
cursor.execute(sql)
cursor.scroll(1,mode='absolute')
result = cursor.fetchone()
print(result)
输出结果:
(2, '公关')
3、
cursor.execute(sql)
cursor.scroll(1,mode='relative')
result = cursor.fetchone()
print(result)
输出结果:
(2, '公关')
7、cursor.fetchmany()

使用法: の数を設定できます。戻り値cursor.fetchmany(num)

cursor.execute(sql)
# cursor.scroll(1,mode='relative')
# result = cursor.fetchone()
# print(result)
result = cursor.fetchmany(2)
print(result)
输出结果:
((1, '财务'), (2, '公关'))
8、cursor.fetchall()

使用法: 名前が示すように、すべての結果を取得します。

sql = "select * from department;"
# 执行sql语句的函数,使用下面函数进行拼接,防止SQL注入
cursor.execute(sql)
# cursor.scroll(1,mode='relative')
# result = cursor.fetchone()
# print(result)
# result = cursor.fetchmany(2)
# print(result)
result = cursor.fetchall()
print(result)
输出结果:
((1, '财务'), (2, '公关'), (3, '测试'), (4, '运维'), (5, '销售'))
9,cursor.lastrowid()

使用方法: 新しく作成したデータの自動インクリメント ID を取得します。複数のデータが追加された場合、自動インクリメント ID のみが取得されます。 -increment 最後に挿入されたデータの ID が返されます。

PS: 1 つだけ必要な場合は、ID を 1 つずつ挿入することしかできません。

sql = "insert into department(title) values(%s)"

cursor.executemany(sql,[('经理')])
# 获取插入值的自增id
print(cursor.lastrowid)
# 将执行的结果提交到表中,否则表不会发生变换
conn.commit()
输出结果:
6
10. 今日の演習

#質問要件:

演習:
権限管理

権限テーブル:
1. 注文管理
2. ユーザー管理
3. メニュー管理
4. 権限割り当て
5. バグ管理
ユーザーテーブル:
1. Cai Xukun
2. チキンブラザー
3. Kun Brother
ユーザー関係権限テーブル:
1 1
1 2
2 1
Python 実装:
ユーザーはログイン後、自分のすべての権限を表示できます

## 質問への答え:

【1、创建权限表】

CREATE TABLE power (
	pid INT auto_increment PRIMARY KEY,
	purview	CHAR(10)
)ENGINE= INNODB DEFAULT CHARSET= utf8;

【2、创建用户表】
CREATE TABLE users (
	uid INT auto_increment PRIMARY KEY,
	username	CHAR(10)
)ENGINE= INNODB DEFAULT CHARSET= utf8;

【3、创建用户权限关系表】
CREATE TABLE use_pow (
	upid INT auto_increment PRIMARY KEY,
	power_id INT,
	user_id INT,
	UNIQUE uq_pid_uid(power_id, user_id),
	CONSTRAINT fk_pow FOREIGN KEY (power_id) REFERENCES power(pid),
	CONSTRAINT fk_user FOREIGN KEY (user_id) REFERENCES users(uid)
)ENGINE= INNODB DEFAULT CHARSET= utf8;

py文件:
import pymysql
user = input('请输入用户名称>>>')
# 连接数据库
conn  = pymysql.connect(host='127.0.0.1', port=3306, 
                  user='root', passwd='@123456', db='db_grant')

# 创建光标
cursor = conn.cursor()

# 查询是否存在该用户
sql = "SELECT uid FROM users WHERE username = %(u)s"

cursor.execute(sql, {'u': user})
# 获取到用户的id
uid = cursor.fetchone()
# print(uid[0], type(uid[0]))
if uid:
# 这里的%s如果换成%d就会报错因为execute无论传入什么类型都要用%s来占位
sql2 = "SELECT purview from power WHERE pid in 
(SELECT power_id FROM use_pow WHERE user_id = %s)"
cursor.execute(sql2, uid[0])
result = cursor.fetchall()
print(result)
else:
print("没有该用户")
cursor.close()
conn.close()

以上がpymysql が mysql データベースを操作する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はyisu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。