開発の背景: 最近、私はバッチ データを MySQL データベースにインポートする機能に取り組んでいます。バッチ インポートから、そのようなデータはデータベースに挿入される前に重複していると判断されないことがわかります。したがって、すべてのデータがインポートされた後にのみ、データの一意性を確保するためにデータを削除するステートメントが実行されます。 詳しい紹介を見てみましょう。 実戦: テーブル構造は次の図に示されています。 意味: ブランド 操作: SQL ステートメントを使用して、重複データがあるかどうかを照会します。 ブランドから*を選択 WHERE brandName IN ( select brandName from brand GROUP BY brandName HAVING COUNT(brandName)>1 #条件は重複データの数が1より大きいことです) SQL を使用して冗長な重複データを削除し、最小の ID を持つ一意のデータを保持します。 注記:
理由は、直接見つかったデータは、データを削除する条件として使用できないためです。まず、見つかったデータの一時テーブルを作成し、その一時テーブルを削除の条件として使用する必要があります。 正しいSQLの書き方: DELETE FROM brand WHERE brandName IN (SELECT brandName FROM (SELECT brandName FROM brand GROUP BY brandName HAVING COUNT(brandName)>1) e) AND Id NOT IN (SELECT Id FROM (SELECT MIN(Id) AS Id FROM brand GROUP BY brandName HAVING COUNT(brandName)>1) t) #重複データのクエリでは最初の数項目のみが表示されるため、最小値かどうかをクエリする必要はありません。 結果は次のとおりです。 要約: 多くのことは、自分で段階的に調べる必要があります。もちろん、インターネット上の提案も非常に貴重な参考資料やリソースです。どのような開発を行うにしても、それをよりよく習得するには、その動作原理を理解する必要があります。 さて、以上がこの記事の全内容です。この記事の内容が皆さんの勉強や仕事に一定の参考学習価値を持つことを願っています。ご質問があれば、メッセージを残してコミュニケーションしてください。123WORDPRESS.COM をご愛顧いただきありがとうございます。 以下もご興味があるかもしれません:
|
>>: Linux の sudo 脆弱性により不正な特権アクセスが発生する可能性がある
目次序文脱構築記号の役割使い方分割割り当ての適用アプリケーションの簡単な紹介JSONデータを抽出する...
目次背景DHCPの設定DHCP ファイル (動的ホスト構成プロトコル) の編集tftp 設定sysl...
この記事では、jsネイティブウォーターフォールフロープラグインの具体的なコードを参考までに共有します...
目次1. fill() 構文2. fill() の使用3. まとめ序文:配列の初期化方法についてはよ...
Web プロジェクトの開発プロセスでは、CSS ファイルや JS ファイルを参照することがよくあり...
実装方法は3つのステップに分かれています。テンプレートに 2 つのボタンを設定し、v-if と v-...
序文Intel のハイパースレッディング テクノロジーにより、1 つの物理コア上で 2 つのスレッド...
js のイベント ループJavaScript はシングルスレッドなので、同じイベントで実行できるメソ...
クローラー対策ポリシー ファイルを追加しました: vim /usr/www/server/nginx...
内容Hyperledger fabric1.4環境のWindows 10でのセットアップ前提条件Wi...
戦争パッケージを準備する1. 既存のSpringBootプロジェクトを準備し、pomに依存関係を追加...
この記事の例では、カスタムスクロールバーを実装するためのjsの具体的なコードを参考までに共有していま...
先週末、兄弟プロジェクトはより良いサービスを提供するためにサーバーを拡張する準備をしていました。兄弟...
この記事では、マウス追従ゲームを実装するためのjsの具体的なコードを参考までに共有します。具体的な内...
レスポンシブレイアウト開発の基礎知識この章は主に以下の部分に分かれています• レスポンシブデザインを...