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

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

新規登録して質問してみよう
ただいま回答率
85.48%
シリアルポート

シリアルポートは一度に一ビットごと移行される物理的なインターフェイスです。一般的には、9ピンのd-subコネクタであるRS-232を指します。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

MariaDB

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Arduino

Arduinoは、AVRマイコン、単純なI/O(入出力)ポートを備えた基板、C言語を元としたArduinoのプログラム言語と、それを実装した統合開発環境から構成されたシステムです。

Q&A

解決済

1回答

4057閲覧

MySQLdb._exceptions.ProgrammingError: 1064を解決したい

sa-mon

総合スコア8

シリアルポート

シリアルポートは一度に一ビットごと移行される物理的なインターフェイスです。一般的には、9ピンのd-subコネクタであるRS-232を指します。

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

MariaDB

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Arduino

Arduinoは、AVRマイコン、単純なI/O(入出力)ポートを備えた基板、C言語を元としたArduinoのプログラム言語と、それを実装した統合開発環境から構成されたシステムです。

0グッド

0クリップ

投稿2021/06/28 02:30

前提・実現したいこと

Arduinoからシリアル通信で得た情報をデータベースに入れる
データベースに入れる際に以下のエラーメッセージが発生しました。

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

MySQLdb._exceptions.ProgrammingError: (1064, "You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near '3'','null')' at line 1")

該当のソースコード

python2.7

1# -*- coding: utf-8 -*- 2import MySQLdb 3import serial 4import time 5 6def main(): 7 s= serial.Serial('/dev/ttyACM0',9600) 8 time.sleep(2) 9 print s.portstr 10 val=s.readline() 11 val=val.strip().decode('UTF-8') 12 print val 13 connector = MySQLdb.connector(db="",user="",passwd="") 14 cursor = connector.cursor() 15 sql = "insert into test (id, value, created) values('4','%s','null')" 16 print sql 17 cursor.execute(sql,[val]) 18 connector.commit() 19 cursor.close() 20 connector.close() 21 22if __name__ == "__main__": 23 main() 24

試したこと

改行文字のreplaceや文字コードの変換

補足情報(FW/ツールのバージョンなど)

MariaDB 10.3
python 2.7
ここにより詳細な情報を記載してください。

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

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

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

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

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

guest

回答1

0

ベストアンサー

エラーメッセージより、パラメータを「'」で囲う必要はないようです。
すなわち"insert ~ values('4','%s',~""insert ~ values('4',%s,~"とするとよいようです。

投稿2021/06/28 02:58

can110

総合スコア38262

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

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

sa-mon

2021/06/28 04:31

ありがとうございます!無事エラー回避できました
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問