質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

MAMP

Mac 上で WordPress などの動的ページのサイトが作れるように環境を構築するフリーソフト

Q&A

解決済

1回答

9299閲覧

pythonのmysql.connectorを使ってデータ取得しようとしたら、"Not all parameters were used in the SQL statement"

oroshitaruuuuu

総合スコア25

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

MAMP

Mac 上で WordPress などの動的ページのサイトが作れるように環境を構築するフリーソフト

0グッド

0クリップ

投稿2018/09/19 17:36

やりたいこと

pythonのmysql.connectorを使い、selectでローカルDBからデータをしたい

環境

Python ver3.6
Mysql ver5.7
MAMP ver5.01

該当のソースコード

cursor.executeするときに、変数が1つの時もタプルにしないといけないと調べてわかったから、変換して引数わたしたけど、エラーは解消されなかった

python

1# test.py 2 3from db import mydb 4 5db = mydb() 6sid = '1' 7sids = db.select_similarity(tuple(sid)) 8#sids = [(1, '183,234,182,172,443,196,236,187,170,208')] 9sids_arr = s_itemsid[0][1].split(',') 10#sids_arr = ['183', '234', '182', '172', '443', '196', '236', '187', '170', '208'] 11for i in range(len(s_arr)): 12 s_item = db.select_item(tuple(sids_arr[0]))←ここでエラー
# db.py import mysql.connector def __init__(self): self.config = { 'user': '*****', 'password': '*****', 'unix_socket': '*****', 'database': '*****', 'raise_on_warnings': *****, } self.conn = mysql.connector.connect(**self.config) self.cursor = self.conn.cursor() ---省略--- def select_item(self,id): cursor = self.cursor query = "select id,title,genre,tags,released_t from t_item where id=%s;" cursor.execute(query,id) return cursor.fetchall()

発生している問題・エラーメッセージ

Traceback (most recent call last): File "/Applications/MAMP/htdocs/***/test.py", line 15, in <module> s_ite = db.select_item(tuple(sids_arr[0])) File "/Applications/MAMP/htdocs/**/db.py", line 106, in select_s_item cursor.execute(query,id) File "/Users/**/Library/Python/3.6/lib/python/site-packages/mysql/connector/cursor.py", line 543, in execute "Not all parameters were used in the SQL statement") mysql.connector.errors.ProgrammingError: Not all parameters were used in the SQL statement

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

s_item = db.select_item(tuple(sids_arr[0]))

Python

1s_item = db.select_item((sids_arr[0], ))

■参考情報
5.3. タプルとシーケンス | docs.python.jp

投稿2018/09/19 19:15

umyu

総合スコア5846

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

oroshitaruuuuu

2018/09/20 13:29

解決できました!ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問