![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?a65a0e2)
やりたいこと:
phpを実行して取得したデータの内容と既にDBのテーブルに格納されているデータを
比較して、
異なっていれば、新しいデータとして INSERT INTO文で
テーブルにデータを登録する。
同じであれば、登録しない。
という処理がしたいです。
$sql = "select * from hoge where url= $page_uri";
$kakunin = mysql_query($sql , $db );
if ( $page_uri == $kakunin ){
//同じデータならスキップ
break;
}
else{
$sql = mysql_query("INSERT INTO hoge VALUES (0,'$page_uri','$pon')");
と書いているのですが、以下のエラーが出てしまいます。。
Fatal error: Cannot break/continue 1 level in /www/xx.php on line 42
これは、breakは使えないよ ってことでしょうか?
breakでなくても やりたいことが実現できればこだわりはないのですが、、
アドバイスよろしくお願いします。
A 回答 (3件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
>これは、breakは使えないよ ってことでしょうか?
RTFM.
http://www.php.net/manual/ja/control-structures. …
breakしてどこに行くのか(制御が移るのか)・・・。whileやforなどであればLoopを抜けますが、そうでなければbreakは書きません(行き先がありません)。breakの代わりにcontinueなら「おかしい」ことはわかりますよね?
>$sql = "select * from hoge where url= $page_uri";
>$kakunin = mysql_query($sql , $db );
>
>if ( $page_uri == $kakunin ){
mysql_queryだけで結果セットを取得するということにはなっていません。mysql_queryの戻り値はresourceです。当然そのresourceからmysql_fecth_arrayなどでレコードを取得しないといけません。
RTFM.
http://php.net/manual/ja/function.mysql-query.php
http://php.net/manual/ja/function.mysql-fetch-ar …
なおSQL文にwhereで条件付けしているのですから、一致かどうかを確認する意味はないです。該当するレコードがあるかどうかだけで判断してかまいません。
$sql = sprintf("select * from hoge where url='%s'",
mysql_real_escape_string($page_uri));
$res = mysql_query($sql);
if (mysql_num_rows($res) = 0) {
$sql = sprintf("INSERT INTO hoge VALUES (0,'%s','%s')" ,
mysql_real_escape_string($page_uri),
mysql_real_escape_string($pon'));
mysql_query($sql) or die('db error');
}
No.1
- 回答日時:
書き方に一貫性がないですね
URIの項目にunique属性がついているなら、IGNOREでINSERTすれば
データがあれば無視、なければ投入になります
$sql = "INSERT IGNORE INTO hoge VALUES (0,'$page_uri','$pon')");
$res= mysql_query($sql);
必要に応じてmysql_real_escape_string()などでエスケープしてください
アドバイスありがとうございます。
URIの項目にunique属性をつけたいのですが、バイト数が1000を超えており
エラーとなってしまうため、unique属性が付けられない状態です・・
*Specified key was too long; max key length is 1000 bytes
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- PHP PHP MySQLに画像を直接保存 2 2022/06/05 11:50
- Oracle 質問です。 下記のテーブルとデータがあり、 取得想定結果のように出力したいです。 下記のsqlだと0 2 2023/05/23 19:10
- PHP PHP MySql ページング 2 2022/09/20 06:38
- PHP ここでの ②if($su_d<>"")の比較演算子 を使う理由は 1 2022/03/26 02:33
- CGI perlで書いたcgiでsqliteの使い方を教えてください 2 2023/05/08 21:29
- MySQL 複数DBテーブルからのデータ取得 3 2022/05/17 15:02
- MySQL 書籍の内容はまともでしょうか? 1 2023/01/22 03:07
- PHP 重複を防ぐ記述について教えて下さい。 3 2023/04/03 14:35
- Ruby pandasでsqlite3にテーブル作成・追加・読み出しでindexの取り扱い方教えてください 5 2023/03/08 09:57
- PHP PHP ページング データベース 1 2022/06/16 10:30
このQ&Aを見た人はこんなQ&Aも見ています
-
見学に行くとしたら【天国】と【地獄】どっち?
みなさんは、一度だけ見学に行けるとしたら【天国】と【地獄】どちらに行きたいですか? 理由も聞きたいです。
-
いちばん失敗した人決定戦
あなたの「告白」での大失敗を教えてください。
-
みんなの【マイ・ベスト積読2024】を教えてください。
積読、ついついしちゃいませんか?そこでみなさんの 「2024年に買ったベスト積読」を聞きたいです。
-
この人頭いいなと思ったエピソード
一緒にいたときに「この人頭いいな」と思ったエピソードを教えてください
-
一番好きなみそ汁の具材は?
みんなで大好きなみそ汁の具材について語り合おうよっ!
-
JSPで<SELECT>の中にDBから持ってきたデータを反映させたい
Java
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・一番好きなみそ汁の具材は?
- ・泣きながら食べたご飯の思い出
- ・「これはヤバかったな」という遅刻エピソード
- ・初めて自分の家と他人の家が違う、と意識した時
- ・いちばん失敗した人決定戦
- ・思い出すきっかけは 音楽?におい?景色?
- ・あなたなりのストレス発散方法を教えてください!
- ・もし10億円当たったら何に使いますか?
- ・何回やってもうまくいかないことは?
- ・今年はじめたいことは?
- ・あなたの人生で一番ピンチに陥った瞬間は?
- ・初めて見た映画を教えてください!
- ・今の日本に期待することはなんですか?
- ・集中するためにやっていること
- ・テレビやラジオに出たことがある人、いますか?
- ・【お題】斜め上を行くスキー場にありがちなこと
- ・人生でいちばんスベッた瞬間
- ・コーピングについて教えてください
- ・あなたの「プチ贅沢」はなんですか?
- ・コンビニでおにぎりを買うときのスタメンはどの具?
- ・おすすめの美術館・博物館、教えてください!
- ・【お題】大変な警告
- ・洋服何着持ってますか?
- ・みんなの【マイ・ベスト積読2024】を教えてください。
- ・「これいらなくない?」という慣習、教えてください
- ・今から楽しみな予定はありますか?
- ・AIツールの活用方法を教えて
- ・最強の防寒、あったか術を教えてください!
- ・歳とったな〜〜と思ったことは?
- ・モテ期を経験した方いらっしゃいますか?
- ・好きな人を振り向かせるためにしたこと
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・これまでで一番「情けなかったとき」はいつですか?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・14歳の自分に衝撃の事実を告げてください
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
テーブルのレコード数を取得し...
-
DB(MySQL)から複数行のデータを...
-
テーブルに入っているデータと...
-
PHP+mysqlでSQL文に文字数制限...
-
住所録を作りたい
-
PHPからデータベースに接続した...
-
実行時エラー3131 FROM 句の構...
-
JAVA SQLServerException 列名 ...
-
MySQLでデータベースにデータin...
-
csvをDBへ読み込んだら、NULLが...
-
mysqlから取得した配列をカンマ...
-
PHPとMySQLで作ったプログラム...
-
PHP(PDO)でDBの情報を完全一...
-
ランダム文字列をDBにINSERT
-
エクセルVBAのデータベース接続...
-
(PHP 4.4.8) sqlite_open関数...
-
Accessへ日付をINSERT
-
checkboxクリック時、SQLを実行...
-
アポストロフィを含む文字列の追加
-
出勤表の作り方
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
sqlから多次元配列に要素を格納...
-
ボタンのonclick時における関数...
-
stringaddslashes 半角¥が消える
-
phpのエラーについてです
-
Resource id #3 をフィールドの...
-
XAMPPで画面が真っ白になります。
-
PHP+mysqlでSQL文に文字数制限...
-
DB(MySQL)から複数行のデータを...
-
PHP+MYSQLで直近3件のデータ表示
-
テーブルのレコード数を取得し...
-
mariadbでのエラー
-
PHP+MYSQL IF文の初歩
-
PHP+MySQLでの検索結果の横並び...
-
リストから詳細画面に遷移する...
-
mysql_queryでDB検索をしたいが...
-
変数内のデータをmysqlのデータ...
-
XAMMPが起動しません。
-
子プロセス終了で閉じてしまうm...
-
CSVをダウンロードさせた際、CS...
-
PHPについて。
おすすめ情報