こんばんは。今MySQLへのデータの挿入時に特殊文字を挿入することが出来ないエラーに悩まされています。初心者で大変申し訳ございませんが、色々と調べてみたのですがどうしても解決できなかった為、質問させて頂きました。お手数をおかけしますがご教授いただければ幸いです。
問題というのは、MySQLへのデータの挿入時の文字列に特殊文字が含まれていた場合、この場合文字列中に「?」が含まれていた場合にこの文字列をinsertすると「?」が「1」に変換されてしまうのです。環境としてはPHPのPEARからの利用で、文字列はDBクラスのquoteメソッドでエスケープしてから挿入しております。文字列の文字コードはEUC-JPです。バックアップ用ファイル(CSV形式のテキストファイル)には正しく記録されておりますのでMySQLの仕様に関しての問題ではないかとは考えておりますが、どうしても解決できず困っております。お手数をおかけしますがよろしくお願いいたします。
No.3ベストアンサー
- 回答日時:
ここが怪しいです.
$result_s = $db -> query($query,DB_FETCHMODE_ORDERED);
下記のURLにあるとおり、$queryのSQL中の ? はプレイスホルダーとなり、DB_FETCHMODE_ORDERED に置換されます。
置換されないようにするには、?の前にバックスラッシュを入れると良いようです。
?以外にも & や ! もプレイスホルダーになるようです。
つまり$URL の文字を1つづつチェックして該当する文字(?&!)があったら、その前に¥を挿入するような処理が必要ですね。
もしくは、逆にプレイスフォルダを利用して、こんな感じで実行できるのではないでしょうか?
$query = 'INSERT INTO s_data (name,url) VALUES( ? , ? )';
$data=arrey( $db -> quote($name) , $db -> quote($url) );
$result_s = $db -> query($query,$data);
※ 上記のコードは、実際にテストはしていないのでそのままでは動かないかもしれません。ごめんなさい。
参考URL:http://www.1x1.jp/php/manual_pear/package.databa …
ありがとうございます。なるほど。。?や&や!はプレイスホルダーとなるのですか。しかも教えて頂いた貴重なPEARのサイトを読んでみるとDBクラスのquoteメソッドがエスケープしてくれるのはシングルクォーテーションだけだという事をはじめて知りました。という事はやはりstr_replace等を利用して事前に変換するしかないということですね。プレイスホルダーを利用した考えも大変参考になりました。とても助かりました。ありがとうございました。
No.2
- 回答日時:
SQLに問題があるのではないかと思います。
$query で組み立てられたSQLはどうなってますか?
この回答への補足
ご回答ありがとうございます。
クエリー文字列はデータベースへ送ると同時にテキストファイルにログとして残しておりまして、
INSERT INTO s_data(name,url) VALUES('名前','http://***.co.jp?id=35')
という風になっているのですが、データベース側のデータはURLの部分がhttp://***.co.jp1id=35という風に?が1に置き換えられて挿入されてしまいます。ちなみに\nなどの改行コードや'などの特殊文字(エスケープ済み)を送ろうとするとエラーが発生し、insertすることはできませんでした。
No.1
- 回答日時:
PHPからMySQLへ挿入されているとのことですが
具体的なコードをみせていただけないでしょうか?
この回答への補足
ありがとうございます。
今回のデータ挿入部分の具体的なPHP側のコードとしましては、以下のようになっております。
ユーザーから入力された名前とWEBサイトURLを登録するだけのものです。
テーブル(s_data)
フィールド
id int(5) auto increment
name text not null
url text not null
↓PHP側↓
.
.
.
require_once("DB.php");
$name = $_POST['name'];
$url = $_POST['url'];
$name = mb_convert_encoding($name,'EUC-JP','auto');
$url = mb_convert_encoding($url,'EUC-JP','auto');
$db = DB::connect("接続文字列",FALSE);
if(DB::isError($db)){die($db -> getMessage());}
$query = 'INSERT INTO ' . s_data . '(name,url) VALUES(' . $db -> quote($name) . ',' . $db -> quote($url) . ')';
$result_s = $db -> query($query,DB_FETCHMODE_ORDERED);
$db -> disconnect();
if(DB::isError($result_s)){die($result_s -> getMessage());}
.
.
.
といった感じになっております。
色々と試してみると、どうやら「?」だけではなく特殊文字全てが挿入不可能のようでした。?は1へと変換され、エラーこそ発生しませんが、「'」などを挿入してみるとinsufficient data suppliedといったエラーが発生してしまいました。DB::quoteメソッドでエスケープされている、、と自分では思い込んでいるのですがコードがおかしいでしょうか?大変お手数をおかけします。よろしくお願いいたします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) VBAで、特定の文字より後を削除して残った数値を文字列に変換と特定の文字より前も削除したい 3 2022/04/15 19:21
- gooブログ Twitterの動画画面をgooブログに埋め込めない 4 2022/06/03 16:40
- Excel(エクセル) エクセルで文字列と数字が混在する列に書式設定したい。 3 2022/12/19 09:11
- Visual Basic(VBA) 特定の文字を簡単な操作で半角スペースに変換するか削除したい 2 2022/11/01 10:35
- Excel(エクセル) capeofdragonと申します Excel2016を使っておりまして 半角又は全角の任意文字列が 2 2022/10/31 13:51
- Visual Basic(VBA) エクセルVBAについて 2 2023/01/31 16:21
- Excel(エクセル) Excelの空文字判定について 7 2023/01/06 13:25
- PostgreSQL PostgressからMySQL(MariaDB)へ構造を変更する際のTimestamp等について 2 2023/04/04 12:09
- その他(プログラミング・Web制作) 変換のプログラムを教えてください。 6 2023/07/01 09:57
- その他(動画サービス) 動画に字幕を挿入する方法を教えてください 1 2023/08/22 21:31
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
MySQLへの特殊文字の挿入について
-
データベースファイル(.db)を開...
-
PL/SQLで@ファイル名が反応しま...
-
作成したレコードセットのCSV出...
-
あるDBから別のDBのテーブルをs...
-
DBファイルの中身を直接見れな...
-
sql*loader 数値のロード
-
wordpressでサイトを作るとき、...
-
mysqlにおけるホストのパーセン...
-
同じSQL文で極端に検索が遅くな...
-
MySQL4.1系でPHPが文字化けして...
-
Access2010でアクセス制限をしたい
-
niftyのラクーカンでのphpMy...
-
【初心者です】SQLPLUSでのバッ...
-
PL/SQLをWindowsのBATファイル...
-
BCPコマンドについて
-
ワークフロー承認システムを作...
-
CentOS(Linux)上の/var/lib/mys...
-
wordpress ブログの(URL)を変更...
-
LinuxでFatal errorが出てしま...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
MySQLへの特殊文字の挿入について
-
MySQLでデータをマージする方法...
-
この場合 JOIN . SELECTはでき...
-
SQLをパソコンでやりたいのです...
-
データベースファイル(.db)を開...
-
PL/SQLで@ファイル名が反応しま...
-
sql*loader 数値のロード
-
あるDBから別のDBのテーブルをs...
-
PL/SQLをWindowsのBATファイル...
-
mysqlにおけるホストのパーセン...
-
同じSQL文で極端に検索が遅くな...
-
SQLです。あってますか?↓
-
数字で「そ」と「り」
-
mySQLのデータベースにhtmlのコ...
-
SQLServerのselect文でデータ数...
-
create databaseがうまくいきま...
-
作成したレコードセットのCSV出...
-
DBファイルの中身を直接見れな...
-
バッチファイルではパスワード...
-
comment on columnについてわか...
おすすめ情報