ビジネスロジックミニプログラムのアクティビティページへのリンクを、テキストメッセージでリンクを送信する(チャネルはsms1、sms2、sms3として記録されます)、またはWeChatミニプログラムのQRコードをポスターに掲載する(チャネルはqrcode1、qrcode2、qrcode3として記録されます)など、さまざまなチャネルを通じて公開します。オフラインメンバーは、QRコードをスキャンしてミニプログラムの指定されたアクティビティページに入ることもできます。または、他のメンバーが共有したミニプログラムリンクを介してミニプログラムに入ることもできます(チャネルはshareとして記録されます)。この記事では、これらの異なる入力方法を総称して異なるチャネルと呼び、これがここで言及するチャネル フィールドです。さまざまなチャネルからアクティビティ ページに入ると、ページ訪問記録が生成されます。 page_view テーブルにカウントされます。 会員がミニプログラムの指定アクティビティページに入り、ページ上で一連の操作を実行すると、ポイントやクーポンの獲得など、対応するフィードバックが届きます。このステップは参加と呼ばれます。このデータは activity_record テーブルに記録されます。 さて、オペレーション担当の女性はデータレポートを求めました。イベントに参加した各メンバーは、どの時間にどのチャネルを通じてイベントに参加しましたか? データテーブル構造
クエリロジック各メンバーは 1 つのアクティビティにしか参加できないため、アクティビティ中にポイントを獲得したり、クーポンを受け取ったりできるのは 1 回だけなど、各メンバーは最大で 1 つの activity_record レコードのみを生成します。 ただし、page_view テーブルの記録方法は異なります。メンバーは、SMS 経由でリンクを受け取ったり、イベントの QR コードをスキャンしたり、イベント リンクを友人に共有してもらったりした可能性があります。これにより、このメンバーに対して複数のページ アクセス レコードが生成されます (つまり、page_view に複数のデータが生成されます)。 考えてみてください。メンバーがイベントに参加するには、まず特定のチャネルを通じてイベント ページにアクセスする必要があります。つまり、view_time の逆順に並べられた複数の page_view データがある場合、activity_record の join_time よりも小さく最も近い view_time が常に存在し、次の page_view の view_time は activity_record の join_time よりも大きくなります。 SQL スクリプトc.member_id、c.view_time、.channel を ( から選択 選択 メンバーID、 SUBSTRING_INDEX( GROUP_CONCAT( view_time ORDER BY view_time DESC ), ',', 1 ) AS view_time, SUBSTRING_INDEX( GROUP_CONCAT( チャネル ORDER BY チャネル DESC ), ',', 1 ) AS チャネル から page_view a LEFT JOIN activity_record b a.member_id = b.member_id の場合 ここで、a.view_time < b.participate_time グループ化 メンバーID) c; スクリプトの説明
これで、MySQL テーブル結合クエリのグループ化と重複排除の実装例についての記事は終了です。MySQL テーブル結合クエリのグループ化と重複排除の詳細については、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
コアコード /*-------------------------------- 2つ以上のフィール...
序文Linux グループは、Linux でユーザー アカウントを管理するために使用される組織単位です...
ページめくりの問題のシナリオBとCは同じページ(表と裏)にありますページをめくって A をカバーした...
HTML は、Baidu 百科事典のナビゲーション ドロップダウン メニュー機能を模倣します。具体的...
序文: js はシングルスレッド言語なので、非同期にすることは不可能です。しかし、js のホスト環境...
目次1. 序文2. ポップアップコンポーネントを2つ見つける3. 自分で作る3.1. Promise...
もちろん、ページ パフォーマンスの最適化に関する個人的な経験も含まれています。ここでいくつかの点につ...
目次意味コンストラクタ本体は異なる戻り値なし戻りオブジェクト非オブジェクトを返すプロパティバインディ...
目次1.Linuxログインインターフェース2. コードを書く3. Makefileを書く4. コンパ...
前回の記事でMySQLサービスが起動しない問題が解決したと分かった後、パスワードなしでrootユーザ...
いくつかの理由(好奇心も含む)から、数週間前に Linux デスクトップとして Xfce を使い始め...
目次1. はじめに2. 本文2.1 フィールドの連結2.2 フィールドでの算術計算の実行1. はじめ...
メタ タグは、ファイル情報を定義し、検索エンジンによる検索を容易にするために Web ページ ファイ...
コードをコピーコードは次のとおりです。 jQuery.cookie = 関数(名前、値、オプション)...
今回はレイアウトを中心に学習しますが、これは基本的なHTMLタグのほとんどにも存在するため、比較的簡...