TreasureDataとMailChimpでユーザ動向に応じたメルマガ配信


MailChimpとは

メールマガジンの配信ツールです。
購読者の登録と管理を行う専用ツールやHTMLメールの作成支援機能、課金管理システムなどを備えており、ウェブブラウザ上で簡単な作業をするだけでオリジナルのメールマガジンを配信することが可能となっています。
日本ではあまり有名ではないですが、アメリカだとかなりポピュラーだそうです。

参考:

TreasureDataとMailChimpの連携

Mailchimpでは、メルマガを配信するためのユーザの登録を行うことができますが、そのユーザがどんなユーザなのかという情報は別途計測して登録したり、メルマガサインアップページのアンケートでユーザに入力してもらったりする必要があります。

しかし、自社のアプリケーションを使っているユーザにメルマガ配信をしようと考えた時に、ユーザを利用状況などに合わせてメルマガ配信を行うことで、より適切な内容を適切なユーザに配信できると考えられます。

TreasureDataでは、購読者のリストと購読者の属性情報をMailChimpに出力するResult Output to MailChimpがリリースされました。
https://docs.treasuredata.com/articles/result-into-mailchimp

これによりトレジャーデータに格納されたアクセスログやアプリケーションログなどを元にしたメルマガ配信が行うことができるようになりました。
この際にはログの情報がが会員情報などと紐付けを行えるようにしておくことが重要です。

例えば

  • 会員登録したけど一定期間アクセスがないユーザに離脱防止のメルマガ配信
  • 高頻度に利用しているユーザに特典のメルマガ配信

など様々なことをトレジャーデータ上のログを元に集計し、定期的に購読者リストをResult Outputによって更新することで実現することができます。

使い方

0. メルマガ配信の目的設定

さて、まずはメルマガを配信する目的を設定して、作業をすすめていきましょう。

今回は、トレジャーデータを利用しているユーザ情報を元にトレジャーデータのコンソールにアクセスして、一定期間アクセスがないユーザにメール配信をしてみましょう。
ここでの一定間隔とは、7日間、30日間の2種類として、特に30日間利用していないユーザへのメール配信を行ってみます。

1. MailChimpの登録

については、前述のリンクを参照してみてください。

2. MailChimpのリストの作成

まずは購読者リストを作成します。

  1. Listを選択し、Create Listを選択する

  2. 必要な基本情報を埋める

  3. このTest_qiitaがメール配信を行う購読者リストになる

3. Groupの作成

Listを作成した後に、そのままでもEmailや名前情報を登録してメール配信ができるようになります。
しかし、各Emailに対して属性を付与することでより細かい条件での配信をするための機能が、Groupです。

  1. "How should we show group options on your signup form?"では、メルマガのサインアップページがあった際に、ユーザにgroupを選択する場合には必要になりますが、今回は必要ないので、4番目を選択する

  2. Group名をretentionとし、それぞれの名前を7daysと30daysとする

3. Result Output to MailChimpの設定

さて、TreasureDataのResult output to MailChimpに必要な情報を集めていきましょう。

  • Mailchimp Apikey (required): MailchimpのAPI keyです。ここを参照してください。
  • Mailchimp List Id (required): Mailchimpで先ほど作成したlistのIDです。ここを参照してください。
  • Update Exisitng (optional, default Yes): Mailchimpでは、Keyが主キーになっています。同一Emailの時にアップデートするか無視するかを選択します。
  • column name for email (optional, default “email”): クエリの結果のEmailの値を保持するカラム名を選択します。
  • column name for first name (optional, default “fname”): 購読者の名を意味するカラム名を選択します。
  • column name for last name (optional, default “lname”): 購読者の姓を意味するカラム名を選択します。
  • column name for group details (optional): 先ほどのようにグループを作成し、その属性をクエリの結果を含めたいときはここに入れます。今回の場合はretentionとします。複数の場合は、カンマで区切って入力します。
  • Replace group (optional, default Yes): ユーザのグループの値をアップデートするかしないかです。

  1. 上記を元にResult output to MailChimpを設定します
  2. 7日間利用していないユーザと30日間利用していないユーザを算出するクエリを作成する。これについてはデータサイエンティストのためのHiveQL分析クエリテンプレート その6の記事を参考にすると良いでしょう。

毎日実行することを考えると例えば下記のような結果を出力するクエリにすると良いでしょう。

SELECT t1.email, t1.firstname as first_name, t1.lastname as last_name,
CASE
   WHEN date_diff('day', t2.day, current_timestamp) = 7 THEN '7days'
   WHEN date_diff('day', t2.day, current_timestamp) = 30 THEN '30days'
   ELSE 'none'
END as retention
FROM
( USER LISTを取ってくるクエリ) t1
left outer Join
( アクセスログを取ってくるクエリ) t2
on t1.user_id = t2.user_id

これで、MailChimpで購読者リストの登録が完了しました。

4. キャンペーンメールを送る

上記で作成したリストに対してメール配信を行ってみます。

  1. キャンペーンメールの種類を選択する。今回は、Regular campaignを選択します。

  2. 配信リストを選択する。今回は、30日間離脱しているユーザに配信を行います。

  3. キャンペーン情報を登録する

  4. メールテンプレートの選択をする

  5. テンプレートを元にメールの内容を作成する

  6. 送信!

これらの流れでメール配信が行えます。

テンプレートを作っておくことで毎日リストを自動で更新して、自動でメール配信をするといった流れが非常に簡単に行えますね!

また、こうしたメール配信のサービスを使うことのメリットとして、開封率のチェックなどが行えることが非常に有益です。

さいごに

TreasureDataとMailChimpをつかって、簡単に様々な条件に切り分けられたユーザに対してメルマガ配信を行う方法を紹介しました。
様々なデータをTreasureDataにためておくことで、マーケティング施策にもいかせるようになり、非常に便利ですね!