(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2024-06-07
(45)【発行日】2024-06-17
(54)【発明の名称】分散システムにわたる統合エンティティビュー
(51)【国際特許分類】
G06Q 30/0201 20230101AFI20240610BHJP
【FI】
G06Q30/0201
【外国語出願】
(21)【出願番号】P 2019173412
(22)【出願日】2019-09-24
【審査請求日】2022-05-06
(32)【優先日】2018-09-24
(33)【優先権主張国・地域又は機関】US
(32)【優先日】2019-01-31
(33)【優先権主張国・地域又は機関】US
【前置審査】
(73)【特許権者】
【識別番号】506332063
【氏名又は名称】セールスフォース インコーポレイテッド
(74)【代理人】
【識別番号】100107766
【氏名又は名称】伊東 忠重
(74)【代理人】
【識別番号】100070150
【氏名又は名称】伊東 忠彦
(74)【代理人】
【識別番号】100135079
【氏名又は名称】宮崎 修
(72)【発明者】
【氏名】レオ デュイ トラン
(72)【発明者】
【氏名】デイヴィッド アングロ
(72)【発明者】
【氏名】デイヴィッド ジェームズ ウッドワード
(72)【発明者】
【氏名】アビナフ チャッダ
(72)【発明者】
【氏名】デイヴィッド ハッカー
(72)【発明者】
【氏名】スティーブン ネス
(72)【発明者】
【氏名】マット ラグロッテ
(72)【発明者】
【氏名】ジェイソン ムーディ
(72)【発明者】
【氏名】ダニエル マーチャント
(72)【発明者】
【氏名】マシュー ジェームズ モンドク
(72)【発明者】
【氏名】フェデリコ レシオ
(72)【発明者】
【氏名】メーメット ゴクメン オルン
(72)【発明者】
【氏名】スティーブン コストシェフスキー
(72)【発明者】
【氏名】クリストファー ビル
(72)【発明者】
【氏名】カウストゥバ バーデ
(72)【発明者】
【氏名】リディア ロドヴィージ
(72)【発明者】
【氏名】サラ フラミオン
(72)【発明者】
【氏名】ジャミン ホール
(72)【発明者】
【氏名】チャールズ ファインマン
【審査官】牧 裕子
(56)【参考文献】
【文献】特開2002-041781(JP,A)
【文献】特開2010-122880(JP,A)
【文献】特表2008-511934(JP,A)
【文献】米国特許出願公開第2013/0290244(US,A1)
(58)【調査した分野】(Int.Cl.,DB名)
G06Q 10/00 - 99/00
(57)【特許請求の範囲】
【請求項1】
コンピューティングデバイスによって、第1スキーマを有する第1データソースからの第1パトロンデータと、第2スキーマを有する第2データソースからの第2パトロンデータを受け取るステップであって、前記第1パトロンデータ及び前記第2パトロンデータは、個々のパトロンに関連付けられる、ステップと;
前記コンピューティングデバイスによって、前記第1パトロンデータ及び前記第2パトロンデータを、マスターレコード・カノニカルモデルの共通交換スキーマに調和させるステップであって、該調和させることは、前記第1スキーマ及び前記第2スキーマを前記マスターレコード・カノニカルモデルの前記共通交換スキーマに接続することを含むステップと;
前記コンピューティングデバイスによって、前記第1パトロンデータのコンテキスト情報及び前記マスターレコード・カノニカルモデルにおけるカノニカル情報に基づいて第1変換ルールと、前記第2パトロンデータのコンテキスト情報及び前記マスターレコード・カノニカルモデルにおけるカノニカル情報に基づいて第2変換ルールとを決定するステップと;
前記コンピューティングデバイスによって、前記第1変換ルールに基づいて前記第1パトロンデータと、前記第2変換ルールに基づいて前記第2パトロンデータをカノニカルフォーマットのレコードに変換するステップと;
前記コンピューティングデバイスによって、前記カノニカルフォーマットのレコードを前記個々のパトロンについてのマスターレコードに書き込むステップと;
前記コンピューティングデバイスによって、前記個々のパトロンについてのマスターレコードの更新に応答して、該更新されたマスターレコードをメッセージングプラットフォームバスにパブリッシュするステップと;
を含む、方法。
【請求項2】
前記コンピューティングデバイスによって、タイブレーカー・ルールを用いて前記個々のパトロンの前記第1パトロンデータと前記第2パトロンデータを調和させるステップ、
を更に含む、請求項1に記載の方法。
【請求項3】
前記コンピューティングデバイスによって、前記第1変換ルール又は前記第2変換ルールを用いてストリーミングデータを処理するステップ、
を更に含み、
前記第1パトロンデータと前記第2パトロンデータのうちの一方は、前記ストリーミングデータを含む、
請求項1に記載の方法。
【請求項4】
前記コンピューティングデバイスによって、前記第1及び第2パトロンデータの前記コンテキスト情報を送信するステップ、
を更に含む、請求項3に記載の方法。
【請求項5】
前記コンピューティングデバイスによって、前記コンテキスト情報に基づいて、前記変換された第1パトロンデータの前記第1データソースと、前記変換された第2パトロンデータの前記第2データソースを決定するステップ、
を更に含む、請求項4に記載の方法。
【請求項6】
メモリと;
前記メモリに結合され、前記メモリ内に格納された命令に基づいて、
第1スキーマを有する第1データソースからの第1パトロンデータと、第2スキーマを有する第2データソースからの第2パトロンデータを受け取り、前記第1パトロンデータ及び前記第2パトロンデータは、個々のパトロンに関連付けられ、
前記第1パトロンデータ及び前記第2パトロンデータを、マスターレコード・カノニカルモデルの共通交換スキーマに調和させ、該調和させることは、前記第1スキーマ及び前記第2スキーマを前記マスターレコード・カノニカルモデルの前記共通交換スキーマに接続することを含み、
前記第1パトロンデータのコンテキスト情報及び前記マスターレコード・カノニカルモデルにおけるカノニカル情報に基づいて第1変換ルールと、前記第2パトロンデータのコンテキスト情報及び前記マスターレコード・カノニカルモデルにおけるカノニカル情報に基づいて第2変換ルールを決定し、
前記第1変換ルールに基づいて前記第1パトロンデータと、前記第2変換ルールに基づいて前記第2パトロンデータをカノニカルフォーマットのレコードに変換し、
前記カノニカルフォーマットのレコードを前記個々のパトロンについてのマスターレコードに書き込
み、
前記個々のパトロンについてのマスターレコードの更新に応答して、該更新されたマスターレコードをメッセージングプラットフォームバスにパブリッシュする、
ように構成される、プロセッサと;
を備える、システム。
【請求項7】
前記プロセッサは、
タイブレーカー・ルールを用いて前記個々のパトロンの前記第1パトロンデータと前記第2パトロンデータを調和させるように更に構成される、
請求項6に記載のシステム。
【請求項8】
前記プロセッサは、
前記第1変換ルール又は前記第2変換ルールを用いてストリーミングデータを処理するように更に構成され、
前記第1パトロンデータと前記第2パトロンデータのうちの一方は、前記ストリーミングデータを含む、
請求項6に記載のシステム。
【請求項9】
前記プロセッサは、
前記第1及び第2パトロンデータの前記コンテキスト情報を送信するように更に構成される、
請求項8に記載のシステム。
【請求項10】
前記プロセッサは、
前記コンテキスト情報に基づいて、前記変換された第1パトロンデータの前記第1データソースと、前記変換された第2パトロンデータの前記第2データソースを決定するように更に構成される、
請求項9に記載のシステム。
【請求項11】
コンピューティングデバイスによって実行されると、該コンピューティングデバイスに、
第1スキーマを有する第1データソースからの第1パトロンデータと、第2スキーマを有する第2データソースからの第2パトロンデータを受け取る動作であって、前記第1パトロンデータ及び前記第2パトロンデータは、個々のパトロンに関連付けられる動作と;
前記第1パトロンデータ及び前記第2パトロンデータを、マスターレコード・カノニカルモデルの共通交換スキーマに調和させる動作であって、該調和させることは、前記第1スキーマ及び前記第2スキーマを前記マスターレコード・カノニカルモデルの前記共通交換スキーマに接続することを含む動作と;
前記第1パトロンデータのコンテキスト情報及び前記マスターレコード・カノニカルモデルにおけるカノニカル情報に基づいて第1変換ルールと、前記第2パトロンデータのコンテキスト情報及び前記マスターレコード・カノニカルモデルにおけるカノニカル情報に基づいて第2変換ルールとを決定する動作と;
前記第1変換ルールに基づいて前記第1パトロンデータと、前記第2変換ルールに基づいて前記第2パトロンデータをカノニカルフォーマットのレコードに変換する動作と;
前記カノニカルフォーマットのレコードを前記個々のパトロンについてのマスターレコードに書き込む動作と;
前記個々のパトロンについてのマスターレコードの更新に応答して、該更新されたマスターレコードをメッセージングプラットフォームバスにパブリッシュする動作と;
を含む動作を実行させる命令を有する、非一時的なコンピュータ読み取り可能装置。
【請求項12】
前記動作は、タイブレーカー・ルールを用いて前記個々のパトロンの前記第1パトロンデータと前記第2パトロンデータを調和させる動作、
を更に含む、請求項11に記載の非一時的なコンピュータ読み取り可能装置。
【請求項13】
前記動作は、前記第1変換ルール又は前記第2変換ルールを用いてストリーミングデータを処理する動作、
を更に含み、
前記第1パトロンデータと前記第2パトロンデータのうちの一方は、前記ストリーミングデータを含む、
請求項11に記載の非一時的なコンピュータ読み取り可能装置。
【請求項14】
前記第1及び第2パトロンデータの前記コンテキスト情報を送信する動作、
を更に含む、請求項13に記載の非一時的なコンピュータ読み取り可能装置。
【請求項15】
前記コンテキスト情報に基づいて、前記変換された第1パトロンデータの前記第1データソースと、前記変換された第2パトロンデータの前記第2データソースを決定する動作、
を更に含む、請求項14に記載の非一時的なコンピュータ読み取り可能装置。
【請求項16】
前記コンピューティングデバイスによって、前記更新されたマスターレコードを、前記個々のパトロンの前記マスターレコードに加入している1つ以上のデータソースに送信するステップ、
を更に含む、請求項
1に記載の方法。
【請求項17】
前記プロセッサは、
前記更新されたマスターレコードを、前記個々のパトロンの前記マスターレコードに加入している1つ以上のデータソースに送信する、
ように更に構成される、請求項
6に記載のシステム。
【発明の詳細な説明】
【背景技術】
【0001】
企業は、自社の製品やサービスの消費者についてのこれまで以上に多くのデータにアクセスできる。CRMシステムの目的は、サプライチェーン内のすべてのサービスレベルで、このデータを効率的に管理し、容易にアクセスして共有できるようにすることである。しかしながら、従来のデータベース又はCRMシステムでは、異なる分離されたソースからの顧客データを統合し、消費者についてのマスターレコードを作成することはできない。また、従来のシステムは、マルチテナントシステムにおいて、クエリを実行し、データを読み出し又は書き込むために、どこからデータを得るかを決定することも困難である。従来のシステムの別の問題は、データの起源(data provenance)、すなわち、レコード内のデータの1つ以上のソースを決定することである。さらに、従来のシステムは、データのための監査ログを提供することに苦労してきた。データの起源と監査ログは、プライバシー法を遵守するために不可欠である。従来のシステムはまた、異なる時間スケールのデータを統合し、異なるソースからのデータにアクセスし、データを比較し、それを調和(reconciling)させるという問題にも直面する。
【発明の概要】
【0002】
典型的なコマース/マーケティングシステムは、高ボリュームで低品質の消費者データを低ボリュームで高品質のデータに変換するために、管理者がコードを作成することを必要とする。このプロセスは、時間がかかり、高価で、エラーを起こしやすい可能性がある。顧客がオンライン・チェックアウト・カートにアイテムを残したままにするとき、すなわち、カートを放置するとき、管理者は、そのようなイベントを追跡して消費者へのフォローアップの電子メールを生成するために、大量のデータを解析するために特定のコードを書かなければならない。さらに、データは、独自のアプリケーション・プログラミング・インタフェース(API)を有する異なるソースから来るので、管理者は、従来的に、各システムのAPIを学んで、異なるシステムとインタフェースしてデータを取り出すためのクエリをプログラムしなければならないであろう。本明細書に提示される実施形態は、特に、少なくともこれらの問題に対する解決策を提供する。
【図面の簡単な説明】
【0003】
本明細書に組み込まれ、明細書の一部を構成する添付の図面は、本実施形態を例示しており、以下の説明とともに、本実施形態の原理を説明し、当業者が本実施形態を作成して使用することを可能にするために更に役立つ。
【0004】
【
図1A】本開示の一実施形態による例示的な動作環境を示す図である。
【
図1B】本開示の一実施形態による例示的な動作環境を示す図である。
【0005】
【
図2】本開示の一実施形態による統合型企業コマース・アーキテクチャを示す図である。
【0006】
【
図3】本開示の一実施形態による消費者解決エンジン(CRE:consumer resolution engine)を示す図である。
【0007】
【
図4】本明細書で提示される様々な実施形態を実施するために使用され得る例示的なコンピュータシステムを示す図である。
【0008】
【
図5】本開示の一実施形態による例示的なユーザインタフェースを示す図である。
【
図6】本開示の一実施形態による例示的なユーザインタフェースを示す図である。
【0009】
【
図7】本開示の一実施形態による例示的なユーザインタフェースを示す図である。
【0010】
本実施形態の特徴及び利点は、図面と併せて考えると、以下で説明される詳細な説明からより明らかになるであろう。図面では、全体を通して同様の参照符号が対応する要素を識別する。図面において、同様の参照番号は一般に、同一の要素、機能的に類似の要素及び/又は構造的に類似の要素を示す。要素が最初に現れる図面は、対応する参照番号の左端の数字で示される。
【発明を実施するための形態】
【0011】
例示的な動作環境
図1Aは、オンデマンドデータベースサービスが使用され得る環境110のブロック図を示す。環境110は、顧客システム112、ネットワーク114、システム116、プロセッサシステム117、アプリケーションプラットフォーム118、ネットワークインタフェース120、テナントデータストレージ122、システムデータストレージ124、プログラムコード126及びプロセス空間128を含んでよい。他の実施形態では、環境110は、列挙された構成要素のすべてを有していなくてもよく、かつ/又は上に列挙された構成要素の代わりに又はそれに加えて、他の構成要素を有してもよい。本開示において、消費者は、顧客又はパトロンと同義に称されることがある。
【0012】
環境110は、オンデマンドデータベースサービスが存在する環境である。顧客システム112は、データベース顧客システムにアクセスするために顧客によって使用される任意のマシン又はシステムであってよい。例えば顧客システム112のいずれかは、ハンドヘルド・コンピューティングデバイス、携帯電話、ラップトップ・コンピュータ、ワークステーション及び/又はコンピューティングデバイスのネットワークであってよい。
図1Aに(
図1Bでより詳細に)図示されるように、顧客システム112は、ネットワーク114を介して、システム116であるオンデマンドデータベースサービスと対話することができる。
【0013】
システム116等のオンデマンドデータベースサービスは、外部顧客に利用可能にされるデータベースシステムである。外部顧客は、データベースシステムの構築及び/又は維持に必ずしも関与する必要はないが、代わりに、そのデータベースシステムは、外部顧客がそのデータベースシステムを必要とするときに(例えば顧客の要求に応じて)使用のために利用可能となり得る。いくつかのオンデマンドデータベースサービスは、共通データベースイメージのテーブルに格納された1つ以上のテナントからの情報を格納して、マルチテナントデータベースシステム(MTS:multi-tenant database system)を形成することができる。したがって、「オンデマンドデータベースサービス116」及び「システム116」は、本明細書では互換的に使用される。データベースイメージは、1つ以上のデータベースオブジェクトを含んでよい。リレーショナルデータベース管理システム(RDMS:relational database management system)又はその均等物が、データベースオブジェクトに対する情報の格納と取り出しを実行してもよい。アプリケーションプラットフォーム118は、システム116のアプリケーションが、ハードウェア及び/又はソフトウェア、例えばオペレーティングシステムを実行することを可能にするフレームワークであってよい。一実施形態では、オンデマンドデータベースサービス116は、アプリケーションプラットフォーム118を含んでよい。アプリケーションプラットフォーム118は、オンデマンドデータベースサービスのプロバイダ、顧客システム112を介してオンデマンドデータベースサービスにアクセスする顧客、あるいは顧客システム112を介してオンデマンドデータベースサービスにアクセスする第三者アプリケーション開発者によって開発された、1つ以上のアプリケーションの作成、管理及び実行を可能にすることができる。
【0014】
顧客システム112のユーザは、それぞれのキャパシティ(capacity)が異なってもよく、特定の顧客システム112のキャパシティは、現在のユーザに対する許可(許可レベル)によって完全に決定されてもよい。例えば販売員が特定の顧客システム112を使用してシステム116と対話している場合、その顧客システム112は、その販売員に割り当てられたキャパシティを有する。しかしながら、管理者がその顧客システム112を使用してシステム116と対話している間は、その顧客システム112はその管理者に割り当てられたキャパシティを有する。階層的役割モデルを有するシステムでは、ある許可レベルのユーザは、より下位の許可レベルのユーザによってアクセス可能なアプリケーション、データ及びデータベース情報へのアクセスは有するが、より上位の許可レベルのユーザによってアクセス可能な特定のアプリケーション、データベース情報及びデータへのアクセスは有しないことがある。したがって、異なるユーザは、ユーザのセキュリティ又は許可レベルに依存して、アプリケーション及びデータベース情報をアクセス及び変更することに関して異なるキャパシティを有する。
【0015】
ネットワーク114は、互いに通信するデバイスのいずれかのネットワーク又はネットワークの組合せである。例えばネットワーク114は、LAN(ローカルエリアネットワーク)、WAN(ワイドエリアネットワーク)、電話ネットワーク、ワイヤレスネットワーク、ポイントツーポイントネットワーク、スターネットワーク、トークンリングネットワーク、ハブネットワーク又は他の適切な構成のうちのいずれか1つ又はいずれかの組合せであってよい。現在使用されているコンピュータネットワークの最も一般的なタイプは、例えば大文字の「I」を用いてしばしば「Internet(インターネット)」と呼ばれるネットワークのグローバル・インターネットワークのような、TCP/IP(Transfer Control Protocol及びInternet Protocol)ネットワークであるので、本明細書の多くの例でこのネットワークを使用することにする。しかしながら、TCP/IPは頻繁に実装されるプロトコルであるが、1つ以上の実装が使用する可能性のあるネットワークはそのように限定されないことを理解すべきである。
【0016】
顧客システム112は、TCP/IPを使用してシステム116と通信することができ、より高いネットワークレベルでは、HTTP、FTP、AFS、WAP等のような他の一般的なインターネットプロトコルを使用することができる。HTTPが使用される例では、顧客システム112は、システム116でHTTPサーバとの間でHTTPメッセージを送受信するための「ブラウザ」と一般的に呼ばれるHTTPクライアントを含むことができる。このようなHTTPサーバは、システム116とネットワーク114との間の唯一のネットワークインタフェースとして実装されてもよいが、他の技術が同様に又は代わりに使用されてもよい。いくつかの実装形態では、システム116とネットワーク114との間のインタフェースは、複数のサーバにわたって負荷をバランスさせて着信HTTP要求を均等に分配する、ラウンドロビンHTTP要求分配器のような負荷共有機能を含む。少なくとも、そのサーバにアクセスしているユーザと同様に、複数のサーバの各々は、MTSのデータへのアクセスを有するが、代わりに、他の代替構成が使用されてもよい。
【0017】
一実施形態では、
図1Aに図示されるシステム116は、ウェブベースの顧客関係管理(CRM:customer relationship management)システムを実装する。例えば一実施形態において、システム116は、顧客システム112との間で関連データ、コード、フォーム、ウェブページ及び他の情報を提供し、データ、オブジェクト及びウェブページコンテンツに関連するデータベースシステムとの間で格納及び取り出しを行うだけでなく、CRMソフトウェアアプリケーションを実装及び実行するようにも構成される、アプリケーションサーバを含む。マルチテナントシステムでは、複数のテナントについてのデータが同一の物理的データベースオブジェクト内に格納されてもよいが、テナントデータは、典型的に、そのようなデータが明示的に共有されない限り、あるテナントが別のテナントのデータへのアクセスを有しないように、あるテナントのデータは他のテナントのデータと論理的に別個に保持されるよう配置される。特定の実施形態では、システム116は、CRMアプリケーション以外のアプリケーション又はこれに加えてアプリケーションを実装する。例えばシステム116は、CRMアプリケーションを含む複合ホスト(標準及びカスタム)アプリケーションへのテナントアクセスを提供することができる。顧客(又は第三者開発者)アプリケーションは、CRMを含んでいても含んでいなくてもよいが、アプリケーションプラットフォーム118によってサポートされる。アプリケーションプラットフォーム118は、アプリケーションの作成、1つ以上のデータベースオブジェクトへのアプリケーションの格納、そしてシステム116のプロセス空間内の仮想マシンにおけるアプリケーションの実行を管理する。
【0018】
システム116の複数の要素の一配置が
図1Bに図示されている。この配置は、ネットワークインタフェース120、アプリケーションプラットフォーム118、テナントデータ123のためのテナントデータストレージ122、システム116及び潜在的に複数のテナントに対してアクセス可能なシステムデータ125のシステムデータストレージ124、システム116の様々な機能を実装するためのプログラムコード126、そしてアプリケーションホスティングサービスの一部としてアプリケーションを実行することのように、MTSシステムプロセス及びテナント固有のプロセスを実行するためのプロセス空間128を含む。システム116上で実行され得る追加のプロセスには、データベースインデックス付けプロセスが含まれる。
【0019】
図1Aに図示されるシステムのいくつかの要素は、ここでは簡単にしか説明されない従来の周知の要素を含む。例えば顧客システム112の各々は、デスクトップ・パーソナル・コンピュータ、ワークステーション、ラップトップ、PDA、携帯電話、あるいは任意のワイヤレス・アクセス・プロトコル(WAP)対応デバイス、あるいはインターネット又は他のネットワーク接続に直接的又は間接的にインタフェースすることが可能な任意の他のコンピューティングデバイスを含むことができる。顧客システム112の各々は、典型的には、HTTPクライアント、例えばMicrosoft(登録商標)のInternet Explorerブラウザ、Netscape(登録商標)のNavigatorブラウザ、Operaのブラウザ、あるいは携帯電話、PDA又は他のワイヤレスデバイスの場合のWAP対応ブラウザ等のブラウジングプログラムを実行し、顧客システム112の顧客(例えばマルチテナントデータベースシステムのサブスクライバ(subscriber))が、ネットワーク114を介してシステム116からそれに利用可能な情報、ページ及びアプリケーションにアクセスし、処理し、表示することを可能にする。また、顧客システム112の各々は典型的に、システム116や他のシステム又はサーバによって提供されるページ、フォーム、アプリケーション及び他の情報と併せてディスプレイ(例えばモニタ画面、LCDディスプレイ等)上でブラウザによって提供されるグラフィカル・ユーザ・インタフェース(GUI)と対話するために、キーボード、マウス、トラックボール、タッチパッド、タッチスクリーン、ペン等のような1つ以上のユーザインタフェースデバイスを含む。例えばユーザインタフェースデバイスは、システム116によってホストされるデータ及びアプリケーションにアクセスして、格納されたデータに対して検索を行うために使用されてよく、そうでなければ、ユーザが、該ユーザに提示され得る様々なGUIページと対話することを可能にすることもできる。上述したように、実施形態は、ネットワークの特定のグローバルなインターネットワークを指すインターネットでの使用に適している。しかしながら、イントラネット、エクストラネット、仮想プライベートネットワーク(VPN)、非TCP/IPベースのネットワーク、任意のLAN又はWAN等の他のネットワークが、インターネットの代わりに使用されてもよいことが理解されるべきである。
【0020】
一実施形態によると、顧客システム112の各々及びその構成要素のすべては、Intel Pentium(登録商標)プロセッサ等の中央処理ユニットを使用して実行されるコンピュータコードを含むブラウザ等のアプリケーションを使用してオペレータ構成可能である。同様に、システム116(及び複数が存在する場合、MTSの追加インスタンス)及びそれらの構成要素のすべては、Intel Pentium(登録商標)プロセッサ等を含み得るプロセッサシステム117等の中央処理ユニット及び/又は複数のプロセッサユニットを使用して実行するよう、コンピュータコードを含むアプリケーションを使用してオペレータ構成可能であってもよい。コンピュータプログラム製品の実施形態は、本明細書で説明される実施形態のプロセスのいずれかを実行するようコンピュータをプログラムするために使用され得る/その上に記憶された命令を有するマシン読取可能な記憶媒体(複数可)を含む。本明細書で説明されるように、ウェブページ、アプリケーション及び他のデータ及び媒体の内容を相互通信して処理するように、システム116を動作及び構成するためのコンピュータコードは、例えばダウンロードされてハードディスクに記憶されるが、そのプログラムコード全体又はその一部は、ROM又はRAMのような周知の任意の他の揮発性又は不揮発性のメモリ媒体又はデバイスに記憶されてもよく、あるいは、フロッピーディスク、光ディスク、デジタル多用途ディスク(DVD)、コンパクトディスク(CD)、マイクロドライブ、磁気又は光カード、ナノシステム(分子メモリICを含む)を含む任意のタイプの回転媒体等のプログラムコードを記憶することができる任意の媒体、あるいは命令及び/又はデータを記憶するのに適した任意のタイプの媒体又はデバイス上に提供されてもよい。加えて、プログラムコード全体又はその一部は、例えばインターネット等のような伝送媒体を介してソフトウェア・ソースから又は公知の別のサーバから伝送されてダウンロードされてよく、あるいは周知であるような任意の通信媒体及びプロトコル(例えばTCP/IP、HTTP、HTTPS、Ethernet(登録商標)等)を使用して、公知の任意の他の従来的なネットワーク接続(例えばエクストラネット、VPN、LAN等)を介して伝送されてよい。また、実施形態を実施するためのコンピュータコードは、クライアントシステム及び/又はサーバ又はサーバシステムで実行され得る、例えばC、C++、HTML、他のマークアップ言語、Java(登録商標)、JavaScript(登録商標)、ActiveX、VBScript等の他の任意のスクリプト言語及び周知の他の多くのプログラミング言語で実行可能な任意のプログラミング言語で実装可能であることも理解されよう(JavaはSun Microsystems社の登録商標である)。
【0021】
一実施形態によれば、システム116は、システム116のテナントとして顧客システム112によるアクセスをサポートするために、ウェブページ、フォーム、アプリケーション、データ及びメディアコンテンツを顧客(クライアント)システム112に提供するように構成される。したがって、システム116は、データが共有されない限り、各テナントのデータを別個に保持するセキュリティ機構を提供する。2つ以上のMTSが使用される場合、それらは互いに近接して配置されるか(例えば単一の建物又はキャンパス内に配置されるサーバファーム内)、互いに離れた位置に分散されてよい(例えばA市内に配置される1つ以上のサーバと、B市内に配置される1つ以上のサーバ)。本明細書で使用されるように、各MTSは、1つ以上の地理的位置にローカルに又はこれらにまたがって分散される、1つ以上の論理的及び/又は物理的に接続されるサーバを含むことができる。さらに、用語「サーバ」は、処理ハードウェア及びプロセス空間を含むコンピュータシステム、並びに本技術分野で周知の関連するストレージシステム及びデータベースアプリケーション(例えばOODBMS又はRDBMS)を含むように意図される。また、「サーバシステム」及び「サーバ」は、本明細書ではしばしば互換的に使用されることも理解されるべきである。同様に、本明細書で説明されるデータベースオブジェクトは、単一のデータベース、分散データベース、分散データベースの集合、冗長的なオンライン又はオフラインバックアップ又は他の冗長性を有するデータベース等として実装されてよく、分散データベース又はストレージネットワーク及び関連する処理インテリジェンスを含むことができる。
【0022】
図1Bも環境110を図示している。しかしながら、
図1Bでは、システム116の要素と、一実施形態における様々な相互接続が更に図示されている。
図1Bは、顧客システム112の各々が、プロセッサシステム112A、メモリシステム112B、入力システム112C及び出力システム112Dを含み得ることを示している。
図1Bは、ネットワーク114及びシステム116を示す。
図1Bはまた、システム116がテナントデータストレージ122、テナントデータ123、システムデータストレージ124、システムデータ125、ユーザインタフェース144(UI)、アプリケーションプログラムインタフェース(API)146、PL/SOQL 148、保存ルーチン150、アプリケーションセットアップ機構152、アプリケーションサーバ130、システムプロセス空間132、テナントプロセス空間134、テナント管理プロセス空間136、テナントストレージエリア138、顧客ストレージ140及びアプリケーションメタデータ142を含み得ることも示している。他の実施形態において、環境110は、上記に列挙されたものと同じ要素を有さなくてもよく、かつ/又は上記に列挙されたものに代えて又はそれに加えて、他の要素を有してもよい。
【0023】
顧客システム112、ネットワーク114、システム116、テナントデータストレージ122及びシステムデータストレージ124は、
図1Aで上述した。顧客システム112に関して、プロセッサシステム112Aは、1つ以上のプロセッサの任意の組合せであってよい。メモリシステム112Bは、1つ以上のメモリデバイス、短期及び/又は長期メモリの任意の組合せであってよい。入力システム112Cは、1つ以上のキーボード、マウス、トラックボール、スキャナ、カメラ及び/又はネットワークへのインタフェースのような入力デバイスの任意の組合せであってよい。出力システム112Dは、1つ以上のモニタ、プリンタ及び/又はネットワークへのインタフェースのような出力デバイスの任意の組合せであってよい。
図1Bに図示されるように、システム116は、HTTPアプリケーションサーバ130、(
図1Aの)アプリケーションプラットフォーム118、テナントデータストレージ122及びシステムデータストレージ124のセットとして実装される(
図1Aの)ネットワークインタフェース120を含んでもよい。また、個々のテナントプロセス空間134及びテナント管理プロセス空間136を含むシステムプロセス空間132も示されている。各アプリケーションサーバ130は、テナントデータストレージ122及びその中のテナントデータ123、並びにシステムデータストレージ124及びその中のシステムデータ125にアクセスして、顧客システム112の要求に応えるように構成されてよい。テナントデータ123は、個々のテナントストレージエリア138に分割されてよく、これはデータの物理的配置及び/又は論理的配置のいずれかであってよい。各テナントストレージエリア138内において、顧客ストレージ140及びアプリケーションメタデータ142は、各顧客に対して同様に割り当てられてもよい。例えば顧客の最も最近使用された(MRU:most recently used)アイテムのコピーが顧客ストレージ140に記憶されてもよい。同様に、テナントである組織全体についてのMRUアイテムのコピーが、テナントストレージエリア138に記憶されてもよい。UI144はユーザインタフェースを提供し、API146はシステム116常駐プロセスに対するアプリケーション・プログラム・インタフェースを、顧客システム112の顧客及び/又は開発者に提供する。テナントデータ及びシステムデータは、1つ以上のデータベース等の様々なデータベースに記憶されてよい。
【0024】
アプリケーションプラットフォーム118は、アプリケーション開発者によるアプリケーションの作成及び管理をサポートするアプリケーションセットアップ機構152を含み、これは、例えばテナント管理プロセス136によって管理される1つ以上のテナントプロセス空間134として、サブスクライバによる実行のために、保存ルーチン150によってメタデータとしてテナントデータストレージ122に保存され得る。このようなアプリケーションに対する起動(Invocations)は、API146に対するプログラミング言語スタイルインタフェース拡張を提供するPL/SOQL148を使用してコード化されてよい。いくつかのPL/SOQL言語の実施形態の詳細な説明は、「Method and system for allowing access to developed applications via a multi-tenant on-demand database service」という名称の2007年9月21日に出願された共通所有の米国特許第7,730,478号に記載されており、これはすべての目的のためにその全体が本明細書に組み込まれている。アプリケーションに対する起動は、1つ以上のシステムプロセスによって検出されてよく、このプロセスは、サブスクライバが起動を行うためにアプリケーションメタデータ142を取り出し、メタデータを仮想マシン内のアプリケーションとして実行することを管理する。
【0025】
各アプリケーションサーバ130は、異なるネットワーク接続を介して、例えばシステムデータ125及びテナントデータ123へのアクセスを有するデータベースシステムに通信可能に結合され得る。例えばあるアプリケーションサーバ130-1はネットワーク114(例えばインターネット)を介して結合されてよく、別のアプリケーションサーバ130-Nは直接ネットワークリンクを介して結合されてよく、別のアプリケーションサーバ130-Nは更に異なるネットワーク接続によって結合されてよい。転送制御プロトコル及びインターネットプロトコル(TCP/IP)は、アプリケーションサーバ130とデータベースシステムとの間で通信するための典型的なプロトコルである。しかしながら、使用されるネットワーク相互接続に応じて、システムを最適化するために他のトランスポートプロトコルが使用されてもよいことは、当業者には明らかであろう。
【0026】
特定の実施形態では、各アプリケーションサーバ130は、テナントである任意の組織に関連付けられる任意のユーザの要求を処理するように構成される。何らかの理由でいつでもアプリケーションサーバをサーバプールに追加し、サーバプールから除去できることが望ましいため、特定のアプリケーションサーバ130に対する顧客及び/又は組織のためのサーバ・アフィニティは存在しない。したがって、一実施形態では、負荷分散機能(例えばF5 Big-IPロードバランサ)を実装するインタフェースシステムは、アプリケーションサーバ130と顧客システム112との間で通信可能に結合され、要求をアプリケーションサーバ130に分配する。一実施形態では、ロードバランサは、最小限の接続アルゴリズムを使用して、顧客要求をアプリケーションサーバ130にルーティングする。ラウンドロビン及び観測応答時間のような負荷分散アルゴリズムの他の例が使用されてもよい。例えば特定の実施形態では、同じ顧客からの3つの連続した要求が3つの異なるアプリケーションサーバ130に当たる可能性があり、異なる顧客からの3つの要求が同じアプリケーションサーバ130に当たる可能性がある。このように、システム116はマルチテナントであり、この場合、システム116は、異種の顧客及び組織にわたる異なるオブジェクト、データ及びアプリケーションのストレージ及びそれらへのアクセスを処理する。
【0027】
ストレージの例として、あるテナントは、各販売員がシステム116を使用して販売プロセスを管理する販売陣(sales force)を雇用する会社であり得る。したがって、顧客は、連絡先データ(contact data)、リードデータ(lead data)、消費者フォローアップデータ、パフォーマンスデータ、目標及び進捗データ等を維持してよく、これらすべてが(例えばテナントデータストレージ122内の)その顧客の個人販売プロセスに適用可能である。MTS構成の例では、アクセス、表示、修正、報告、送信、計算等すべきデータ及びアプリケーションのすべてが、ネットワークアクセス以上のものを持たない顧客システムによって維持及びアクセスされ得るので、顧客は、多くの異なる顧客システムのいずれかから販売努力及びサイクルを管理することができる。例えば販売員が顧客を訪問しており、顧客がそのロビー内でインターネットアクセスを提供している場合、販売員は、顧客がロビーに到着するのを待っている間に、その顧客に関する重要な更新を得ることができる。
【0028】
各ユーザのデータは、各ユーザの雇用者に関わらず、他のユーザのデータから分離されてよいが、一部のデータは、テナントである所与の組織について、複数のユーザ又は全ユーザによって共有又はアクセス可能な組織全体にわたるデータであり得る。したがって、テナントレベルで割り当てられ、システム116によって管理されるいくつかのデータ構造が存在し、他のデータ構造は、ユーザレベルで管理されてよい。MTSは、潜在的な競合相手を含む複数のテナントをサポートする可能性があるため、MTSは、データ、アプリケーション及びアプリケーションの使用を別々に保持するセキュリティプロトコルを持つべきである。また、多くのテナントは独自のシステムを維持するのではなく、MTSへのアクセスを選択する可能性があるため、冗長性、アップタイム及びバックアップは、MTSで実装される可能性がある追加機能である。ユーザ固有のデータ及びテナント固有のデータに加えて、システム116は、複数のテナント又は他のデータによって使用可能なシステムレベルのデータも維持してよい。このようなシステムレベルのデータには、テナント間で共有可能な産業レポート、ニュース、投稿等が含まれる。
【0029】
特定の実施形態では、顧客システム112(クライアントシステムであってもよい)は、アプリケーションサーバ130と通信して、システム116からのシステムレベル及びテナントレベルのデータを要求及び更新する。これは、1つ以上のクエリをテナントデータストレージ122及び/又はシステムデータストレージ124に送信することを必要とすることがある。システム116(例えばシステム116内のアプリケーションサーバ130)は、所望の情報にアクセスするように設計される1つ以上のSQLステートメント(例えば1つ以上のSQLクエリ)を自動的に生成する。システムデータストレージ124は、データベースから、要求されたデータにアクセスするためのクエリプランを生成することができる。
【0030】
各データベースは、一般に、予め定義されたカテゴリに適合されたデータを含む、論理テーブルのセットのような、オブジェクトの集合として見ることができる。「テーブル」は、データオブジェクトの1つの表現であり、ここでは、オブジェクト及びカスタムオブジェクトの概念的な説明を簡略化するために、テーブルを使用することができる。「テーブル」及び「オブジェクト」は、本明細書において互換的に使用され得ることが理解されるべきである。各テーブルは、一般に、表示可能スキーマ内の列又はフィールドとして論理的に配置される1つ以上のデータカテゴリを含む。テーブルの各行又はレコードは、フィールドによって定義される各カテゴリのデータのインスタンスを含む。例えばCRMデータベースは、名前、住所、電話番号、ファックス番号等の基本連絡先情報のためのフィールドを有する顧客を記述するテーブルを含むことができる。別のテーブルは、顧客、製品、販売価格、日付等の情報のフィールドを含む発注書(purchase order)を記述してよい。一部のマルチテナントデータベースシステムでは、すべてのテナントによる使用のために標準エンティティテーブルが提供されてよい。CRMデータベースアプリケーションでは、そのような標準エンティティは、予め定義されたフィールドを各々含む、アカウント、連絡先、リード(Lead)及び機会データ(Opportunity data)のテーブルを含んでよい。「エンティティ」という用語は、本明細書において「オブジェクト」及び「テーブル」と互換的に使用されることもあることを理解されたい。
【0031】
いくつかのマルチテナントデータベースシステムでは、テナントは、カスタムオブジェクトを作成及び格納することを許容されてもよく、あるいは例えばカスタムインデックスフィールドを含む標準オブジェクトのカスタムフィールドを作成することによって、標準エンティティ又はオブジェクトをカスタマイズすることが許容されてもよい。「Custom Entities and Fields in a Multi-Tenant Database System」という名称の2004年4月2日に出願された米国特許第7,779,039号は、参照によって本明細書に組み込まれる。特定の実施形態では、例えばすべてのカスタムエンティティデータ行が、組織ごとに複数の論理テーブルを含み得る単一のマルチテナント物理テーブルに格納される。複数の「テーブル」が実際には1つの大きなテーブルに格納されていること、あるいは彼らのデータが他の顧客のデータと同じテーブルに格納される可能性があることが、顧客には見えない。
【0032】
本明細書において互換的に称される「顧客」、「会社」又は「クライアント」は、CRMサービスに加入している会社を指す。例えばCrocs(登録商標)のような企業は、CRMサービスに加入することができ、本明細書では顧客と称される。本明細書において称されるとき、消費者とは、顧客から、例えば顧客のウェブサイト、顧客の店舗又は顧客による対面販売から、製品又はサービスを購入する個人を指す。
【0033】
統合型企業コマース・アーキテクチャ(Integrated Enterprise Commerce Architecture)
図2は、本開示の一実施形態による統合型企業コマース・アーキテクチャ201を図示している。アーキテクチャ201は、
図1A~
図1B内のシステム116及び環境110の一部である。
【0034】
図2において、ローイベント(raw event)バス200は、複数のソースからローイベント202-1~202-7を受け取る。例えばローイベントバス200は、これに限定されないが、顧客ウェブページ204(例えば消費者によるウェブページ204上のクリック)、演算デバイス206から(例えば消費者のラップトップ又はデスクトップ)、モバイルデバイス208(例えば消費者のスマートフォン及びタブレット)、モノのインターネット(IoT)224の機能を有するモバイルデバイス210、コアデータベース214、マーケティング・クラウド(「MC:marketing cloud」)216及びコマース・クラウド(「CC:commerce cloud」)218を含むものからデータを受け取る。一例として、顧客が、顧客ウェブサイト204上でアイテムをクリックしてそのアイテムを見る場合、顧客は、そのアイテムをオンラインカートに追加するか、あるいは、顧客がオンラインカートからアイテムを除去する場合、アクティビティのローイベントが生成され、制御タグに関連付けられる。制御タグ220-1~220-3、サーバイベント222-1~222-3及びIOT 224は、どのイベントがローイベントバス200に送信されるかを決定するために使用される。顧客及びクライアント・デバイスは、rawevents.salesforce.comのような特定のインターネットプロトコル(IP)アドレスにローイベントを送信することによって、ローイベントをローイベントバス200にパブリッシュすることができる。
【0035】
ローイベントは、典型的に、高ボリュームで低品質のデータである。本明細書で提示される実施形態は、高ボリュームで低品質のデータを低ボリュームで高品質のデータに変換する。従来、管理者は、高ボリュームで低品質のデータを低ボリュームで高品質のデータに変換するコードを作成しなければならなかった。本明細書で提示される実施形態は、この機能を実行するためのポイント・アンド・クリック・ソフトウェア(point-and-click software)を提供し、それにより、そのような変換に必要とされる時間及びコストを大幅に削減する。
【0036】
ローイベント計算器226は、マーケティング・クラウド予測インテリジェンス(MC PI(predictive intelligence))228、コマース・クラウド予測インテリジェンス(CC PI)230及びローイベントバス200を介して受け取ったローイベントをソートするためのKrux 232のような複数のモジュールを含み、高ボリュームで低品質のデータを低ボリュームで高品質のデータに変換する。例えばMC PI228は、ローイベントバス200からのイベントを解析して、消費者によってオンライン・チェックアウト・カートに追加されているもの又はオンライン・チェックアウト・カートから削除されているものを決定する。イベントは、カートを識別するためのカート識別情報(ID)を含むことができる。放置カート・イベント(abandoned cart event)、すなわち、消費者がカートにアイテムを追加したが、チェックアウトせず、トランザクションを完了していないイベントがある場合、MC PI228は、放置カート・イベントを、企業メッセージングプラットフォーム(EMP:Enterprise Messaging Platform)バス234に発行する。同様に、カートが、特定のプログラム可能な期間にわたって追加又は削除のようなイベントを見なかった場合、MC PI228は、そのイベントをEMPバス234に出す。ローイベントバス200及びEMPバス234は、1つの大きなバスとすることができる。しかしながら、ローイベントバス200は、データボリュームが高い可能性があり、顧客又はアプリケーションの所に直接行かない可能性のあるローイベントを処理し、一方、EMPバス234は、トランザクションの更なる詳細を有する可能性があるビジネスイベントを処理する。さらに、ローイベントバス200は、誰がそれに対するアクセスを有するのか否かを定義することができるだけであるが、EMPバス234は、「誰が何のイベントをいつ取得することを許可されるか」を定義することができるセキュリティモデルを有する。EMPバス234は、異種の異なる顧客のための共通の抽象化層と、異なるシステムにわたるイベントのための共通の共有バスを提供することができる。EMPバス234に進むイベントは、プラットフォームを取り囲む任意のシステムに進むことができる。しかし、異なる顧客及び異なるシステムは、EMPバス234を介して互いに直接通信することはできない。EMPバス234上のイベントは、安全に相互から隔離される。
【0037】
EMPバス234は、イベント・パブリッシュ/イベント・サブスクライブルールを許可する。イベント・パブリッシュ/イベント・サブスクライブルールは、顧客によってEMPバス234にパブリッシュされ得るイベントと、顧客によってEMPバス234にサブスクライブされ得るイベントと、顧客がEMPバス234上の特定のイベントにサブスクライブするときに起こることを提供する。パブリッシュルールをセットアップすると、例えば「EMEA」のRecordTypeを有するPersonAccountsのみを公開することのように、所与のイベントにフィルタ基準を適用して、どのように共有されるかを制限することができる。そして、所与のイベントについて、EMPバス234にパブリッシュする前に、追加情報でペイロードを充実させることができる。例えばRecordType情報を所与の顧客データ変更(CDC:customer data change)イベントに追加し、それにより、サブスクライバはフィルタを適用することができる。同様に、サブスクリプション・ルールをセットアップするとき、共有EMP234からイベントを取り出すときにフィルタ基準を適用することができる。例えばフィルタ基準は、「NorthAmerica」のRecordTypeを有するPersonal Accountのみを処理するようにセットアップすることができる。EMPバス234は、アクションを生成するために使用することができる顧客トリガイベントを提供することができる。例えば放置されたカートを例にとると、放置カート・イベントがEMPバス234上でパブリッシュされた後、それをEMPバス234にサブスクライブして、EMPバス234から取り出すことができる。放置カート・イベントは、トリガイベントとすることができる。そして、カートを放置した消費者にリマインドする電子メール・アクションを生成することができる。
【0038】
イベントルータ/バッファ236は、イベント・パブリッシュ/イベント・サブスクライブルールのサポートを提供する。EMPバス234上で発行されたイベントは、時系列順であり、72時間のような一定の期間を超えるイベントを、ドロップオフすることができる。したがって、新たにパブリッシュされたイベントは、以前にパブリッシュされたイベントを下に、例えば
図2に図示されるように左に押し下げることができる。異なる顧客は、その期間の異なる時点で互いに独立にEMPバス234上のイベントにサブスクライブすることができる。例えば
図2に図示されるように、Core214は、EMPバス234上で新たにパブリッシュされたイベントにサブスクライブすることができる。EComm254は、システムのアップグレードのために24時間停止(bring down)されることがある。EComm254が立ち上がった(bring up)後、24時間前にパブリッシュされたイベントにサブスクライブすることができる。
【0039】
イベント・パブリッシュ/イベント・サブスクライブルールは、イベントのスキーマ、バージョン及びセキュリティを定義することができる。異なる顧客がEMPバスにパブリッシュ/サブスクライブする場合、異なる顧客のために別個の業務を分離することにより、開発ライフサイクルの効率を改善することができる。例えばイベントの新たなバージョンをパブリッシュすることのように、Core214に対する更新が存在する。従来的に、EComm254、OMS256、MC216及び第三者システム258は、互いに通信するために1対1の接続を有しているが、システムの故障を避け、Core214によって発行されるイベントの新しいバージョンを処理するために、同時にアップグレードし、すべて一度に立ち上げる必要がある。EMPバス234では、EComm254、OMS256、MC216及び第三者システム258のシステムは、Core214のアップグレードの後に異なる時点でアップグレードすることができ、その後、異なる時点でEMP234からの新しいバージョンのイベントにサブスクライブすることができる。ここに提示される実施例は、イベント・パブリッシュ/イベント・サブスクライブルールのためのポイント・アンド・クリック・ユーザインタフェース(UI)の簡単な使用を提供し、そのようなUIは、顧客の管理者がEMPバス234にパブリッシュされるべきデータ及びEMPバス234からサブスクライブされるべきデータを選択することを可能にする。
【0040】
CC PI230は、消費者のブラウジング履歴に基づいて製品推奨を提供する。例えば消費者が顧客ウェブサイト204でクリックし、オンラインカートに追加又はオンラインカートから削除したアイテムに基づいて、CC PI230は、第三者及び内部データソースに基づき、製品推奨を生成することができる。製品推奨はEMPバス234上に配置される。
【0041】
Krux232はユーザトラフィックをセグメント化する。Krux232は、ユーザのクリックを追跡してトラフィックを異なるバケットにセグメント化することを可能にするUIを有する。例えばKrux232は、Krux関連制御タグに基づいてデータをセグメント化することができる。例えば制御タグは、例えばカリフォルニアのように、トラフィックが発生した一般的な場所や、消費者が男性アイテムをクリックしたか女性アイテムをクリックしたか等のようなデータを含むことができる。制御タグ220からのデータを用いて、Kruxは、位置、性別、年齢等によってデータをセグメント化することができる。したがって、ローイベント計算器226は、高ボリュームで低品質のデータを低ボリュームで高品質のデータに変換し、フィルタされたデータをEMPバス234に配置する。
【0042】
クロスクラウド・アプリケーション・コンポーネント238は、システム間のシームレスな経験及びデータへのアクセスを提供することによって、統合システムの価値を強調する。クロスクラウド・アプリケーション・コンポーネント238は、コマース・ジャーニー(Commerce journeys)・イベントハンドラ240、ジャーニー・ビルダ(journey builder)242、ランタイム・コンポーネント244、仮想エンティティ246及びセットアップUI248を含む。コマース・ジャーニー・イベントハンドラ240は、ローイベント計算器226によってフィルタされ、EMPバス234を介して受け取られたイベントに対してアクションをとる。例えばコマース・ジャーニー・イベントハンドラ240は、放置カート・イベントについてEMPバス234をモニタし、消費者が購入したいかもしれないカート内に残されたアイテムについて消費者にリマインドする電子メールのデータを生成する。ジャーニー・ビルダ242は、コマース・ジャーニー・イベントハンドラ240によって生成されたデータに基づいて、電子メールを構築して送信する。
【0043】
例えば消費者がショッピングカートにアイテムを追加すると、「カートに追加」イベントがローイベントバス200上に生成される。MC PI228は、消費者のショッピングカートに関連付けられる、放置カート・カウンタ・オペレーション(abandoned cart counter operation)を開始又は再開する。一定期間、例えば2日間が経過した後、MC PI228は、EMP234に「放置カート」イベントを発行する。コマース・ジャーニー・イベントハンドラ240は、「放置カート」イベントをリッスンする。イベントを受け入れると、コマース・ジャーニー・イベントハンドラ240は、クエリハンドラ264を介して、消費者のアイデンティティ及び電子メールアドレスのように、放置されたカートに関連付けられる追加情報を要求する。この情報を利用して、ジャーニー・ビルダ242は消費者への通信を生成して送信する。例えばジャーニー・ビルダ242は、消費者に製品への関心を思い出させるため又は割引を提示するための電子メールを生成することができる。各ジャーニーの属性は、ポイント・アンド・クリック・ツールを使用してユーザが定義することができる。この点に関して、ジャーニー属性を決定するように追加の予測ロジックも構成されてもよい。例えばCC PI230のような計算器はまた、テナントに対する消費者の商業的価値に基づく割引の金額等の情報を、EMP234を介してコマース・ジャーニー・イベントハンドラ240に提供することができる。従来の方法は、顧客の管理者が、ローデータを通して解析し、放置カート・イベントを決定し、電子メールを生成するためのコードを書くことを必要とするが、本明細書で提示される実施形態は、このような電子メールをシームレスかつ透明に生成することを可能にするポイント・アンド・クリック・ツールを透明に提供する。クロスクラウド・アプリケーション・コンポーネント238によって処理される追加のコマース・ジャーニー・イベントは、カートの除去又は追加のような追加のコマース・イベントを含んでもよい。他のイベントには、消費者関連の変更イベント、メーリングリストの登録解除等の同意イベント、注文イベント(例えば注文のステータスに関する電子メールの生成)及び他のマーケティングイベントが含まれてよい。
【0044】
ランタイム・コンポーネント244(「小売ランタイム(retail runtime)UIウィジェット」とも呼ばれる)は、カスタマイズされたUIツールのセットである。例えばランタイム・コンポーネント244は、イメージ・フレーム(IFrame)UIツール(図示せず)を含み、これは、例えばマーケティング電子メール又は消費者に放置カートを思い出させる電子メールへの製品イメージの統合的な表示及び配置を可能にする。従来、製品イメージのこのような抽出は広範なコーディングを必要とするが、IFrameツールは、このようなイメージのポイント・アンド・クリック抽出を可能にする。ランタイム・コンポーネント244はまた、コマース・クラウド218及びマーケティング・クラウド216のような他のシステムからのデータのカスタマイズされたビューを提供するリストビューツール(図示せず)を含む。仮想エンティティ246は、第三者システムとの統合のために共通のクエリレイヤを提供する。仮想エンティティ246は、データ連携サービス(data federation service)に委任して、様々なシステムにわたってデータをクエリするための一貫したインタフェースを提供する。これにより、データを複数のシステムからクエリして、そのようなシステムにアクセスしようとするユーザのために複雑さを減少させることができる。
【0045】
セットアップUI248(本明細書では「クロスクラウド・セットアップUI」とも呼ばれる)は、ユーザがシステムによって提供される異なるアプリケーション間の接続性を構成することを可能にする、統合されたUI体験を提供する。また、ユーザがスキーマをマッピングして、消費者解決エンジン(CRE:Consumer Resolution Engine)250を構成することも可能にする。セットアップUI248は、ビジネスユーザがユーザ側の高度な技術的能力を必要とすることなく、異なるアプリケーションを構成することを可能にする。セットアップUI248を使用して行われた変更は、以下に更に説明されるメタデータサービス252に保存される。一実施形態では、セットアップUI248は、プログラム開発者が独自のUIを作成することを可能にし、それにより、UIフレームワークをマイクロサービスとして顧客に提供する。
【0046】
Core214は、コア製品及びサービスのデータベースである。Core214は、セールス・クラウド、サービス・クラウド、コミュニティサービス、産業サービス、プラットフォームサービスを含む。マーケティング・クラウド216とコマース・クラウド218は別個のクラウドとして示されているが、一例では、マーケティング・クラウド216とコマース・クラウド218はコア214の一部であってよい。
【0047】
Eコマース(E-commerce)データベース254は、店頭Webインタフェースを実行するために使用される情報を格納する。注文管理システム(OMS:Order Management System)256は、消費者の注文データを格納し、発注後の物流(例えば出荷、返品等)を処理するデータベースである。
【0048】
第三者システム258は、企業リソース・プランニング(ERP:Enterprise Resource Planning)システムのように第三者に属するデータベース及びシステムである。例えばAdidas(登録商標)のような顧客は、本明細書の実施形態によってイベント・データ分析のようなサービスを提供するため、あるいは消費者のためにマーケティング・メールを生成するために使用されことになるデータを有するであろう。
【0049】
イベントハンドラ260-1~260-5は、Core、MC、OMS、Eコマース及び第三者システムに関連付けられ、EMPバス234からデータを読み出すため又はEMPバス234上にデータを配置するために使用されるコードである。
【0050】
データ連携サービス(DFS:Data Federation Service)262は、クエリを実行し、レコードからデータを読み出し、書き込み又は削除するために、システムのコンポーネントにプラグインするコネクタのセットを提供する。DFS262は共通のクエリインタフェースを提供するので、顧客は複数のシステムからデータを取得することができる。例えば顧客はクエリを実行し、コマース・クラウド218からオンラインカート上のデータを取得することができる。従来、顧客は、クエリをプログラムしてデータを取り出すために、コマース・クラウド218のためのシステム固有のアプリケーション・プログラミング・インタフェース(API)を使用しなければならないであろう。本明細書に提示される実施形態は、顧客が別個のAPIの使用を差し控えることを可能にし、コア214、Eコマースデータベース254、OMS256、MC216、第三者システム258、CRE250等のような複数の異なる分離されたシステムにわたるクエリのための単一の統一されたAPIを提供する。DFSでは、アップサート(upsert)/削除ハンドラ268は、異なるシステムからの読み出し及び書き戻しを可能にする。DFSキャッシュ270は、パフォーマンス改善のためにデータのローカルコピーを格納する。クエリ実行部(executor)266は、クエリの並列実行のために複数のシステムへ到達させることによってクエリを管理する。クエリハンドラ264は、クエリから生じるエラーシナリオに対処する。
【0051】
共通のクエリインタフェースを提供することによって、DFS262は、仮想スキーマ、すなわち、ディスク上に存在しない目標形状(target shape)に対して、仮想エンティティ246からクエリを受け取ることができる。次に、DFS262は、具体的な論理スキーマに対して実行されるべきクエリを解析することができる。DFS262は、論理スキーマ上でクエリを実行し、目標形状を通して返される結果を提供する。加えて、DFS262は、メタデータサービス252に格納されたメタデータモデル及び変換情報に依存するクエリを実行することができる。これにより、DFS262は、変換情報を使用して、クエリをダウンストリームシステムのアドホック言語に書き換えることができる。例えば結合(join)又はフィールドを含むクエリを生成することができる。ダウンストリームシステムが結合をサポートするかどうかを知ることなく、DFS262は、メタデータモデルに依存することによってクエリを実行することができる。例えばクエリは、別個のドメイン(例えば注文ドメイン及び製品ドメイン)に関連付けられる情報を探すことができる。クエリは、注文、注文明細行項目及びそれぞれの注文に関連付けられる製品情報を探すことができる。従来のクエリではダウンストリームシステムへの別々の呼び出しを介してそのような情報を得ることができる場合、DFS262は、メタデータサービス252によって、単一のクエリ呼び出しでこの情報を取得することを可能にされる。
【0052】
従来のシステムは、マルチテナントシステムにおいて、クエリを実行し、データを読み出し又は書き込むために、どこからデータを得るべきかを決定することが困難である。
図5及び
図6は、マルチテナントのUIの例を示す。
図5のUIは、4つのクラウド、すなわち、コマース・クラウド、サービス・クラウド、セールス・クラウド、マーケティング・クラウドを示している。クラウドの各インスタンスが「テナント」と呼ばれる。例えばCrocs(登録商標)はコマース・クラウドの契約を1件購入している(「Crocs US」)。Crocs USのコマース・クラウドはテナントの一例である。Crocsは、サービス・クラウドの3つの契約を購入している(Crocs North America、Crocs Canada及びCrocs Latin America)。3つのサービス・クラウド契約は、3つの異なるテナントで構成される。同様に、Crocsはセールス・クラウド契約とマーケティング・クラウド契約を購入しており、これらは2つの異なるテナントから構成される。テナントのグローバル・ディレクトリ272は、顧客のテナントを管理するためのソースと、テナントに接続するための認証構成を提供する。例えばCrocsは、北米、カナダ、ラテンアメリカ向けのサービス・クラウドテナントを有してよい。一実施形態では、テナントのグローバル・ディレクトリ272は信頼関係も管理する。例えばテナントのグローバル・ディレクトリ272は、北米とカナダ向けのCrocsサービス・クラウド間の信頼を可能にするが、ラテンアメリカはそうでないとするルールを提供することができる。信頼関係の管理は、一般データ保護規則(「GDPR:General Data Protection Regulation」)等のプライバシー法の遵守も可能にする。例えば顧客によって購入された欧州のクラウドは、欧州のプライバシー法を遵守するために、他の地域のクラウドとの信頼関係を持たない可能性がある。
図5及び
図6は、テナントの代替リストビューを示す。例えば
図5のUIは、3つのサービス・クラウドのテナントが存在し、各々1つのマーケティング・クラウド、セールス・クラウド、コマース・クラウドが存在することを示している。「他のデータ(Other Data)」ボタン及び「セールスフォースデータ(Salesforce data)」ボタンは、顧客が、ERPシステム内の自身のデータ等、Salesforce以外のシステムからの他のデータソースを、Salesforce CRMデータとともに追加することを可能にする。
【0053】
メタデータサービス252は、システムの構成を作成、編集及び格納するためのメタデータ及びスキーマを提供する。マスターレコード・カノニカルモデル(master record canonical models)282は、異なるシステム間のスキーマを調和させる共通交換スキーマ(common exchange schema)を提供する。例えばいくつかのレコードは、ラストネームフィールドを「ラストネーム」の代わりに「ファミリーネーム」と呼ぶ。マスターレコード・カノニカルモデル282は、例えばファミリーネームが「ラストネーム」に解されるような、レコードのための共通スキーマを提供する。フィールドマッピング・レジストリ276は、異なるスキーマを接続する。エンティティスキーマ・レジストリ274は、各テナントの特定のスキーマへのアクセスを提供する。EMPメッセージスキーマ280は、どの種類のイベントがEMPバス234に進むことができ、どの種類のイベントがEMPバス234に進むことができないかについての属性を定義するイベント・レジストリを提供する。CREサービスメタデータ284は、CRE250がどのように動作すべきかを決定する。例えばCRE250がどのようにレコードをマッチングして正規化するべきかを決定する。CRE250は、以下に更に詳細に説明される。DFSメタデータ278は、クエリを使用してDFS262からアクセスすることができる種類のデータを提供する。一実施形態では、メタデータサービス252は、スキーマメタデータのバージョニングのためのサポートも提供する。例えばユーザは、複数の異なるメタデータプロファイルを作成して保存することができる。
【0054】
一実施形態では、クエリハンドラ264は、複数のデータソースにわたってクエリを実行する要求を受け取ることがある。例えばクエリハンドラは、消費者データについてのクエリ要求を受け取ることがある。応答として、クエリハンドラ264は、クエリに関連する第1データソース及び第2データソースを決定する。第1データソース及び第2データソースは、異なるシステムからのものであってよい。クエリハンドラ264は、第1データソース、第2データソース及びマスターレコード・カノニカルモデル282等の共通交換スキーマに格納されたデータを取り出すことによって要求されたクエリを実行し、異なる第1データソースと第2データソースとの間のスキーマを調和させる。
【0055】
消費者解決エンジン(CRE:Consumer Resolution Engine)
従来のデータベース又は顧客関係管理システムでは、特定のシステムにデータをコピーすることなく、異なる分離されたソースからの顧客データを統合して顧客についてのマスターレコードを作成することはできない。従来のシステムの別の問題は、データの起源、すなわち、レコード内のデータの1つ以上のソースを決定することである。さらに、従来のシステムは、データのための監査ログを提供することに苦労してきた。データの起源と監査ログは、プライバシー法を遵守するために不可欠である。例えば顧客がレコードを編集又は削除したい場合、顧客は編集や削除を行うことができる。本明細書で説明されるCRE250は、マルチテナント性、セキュリティ及び規制コンプライアンスを可能にする。実施形態は、データだけでなく、データの周囲のコンテキストも含む、消費者の全体的なビューを構築する。データのソースには、現在既知のタッチポイントと未来のタッチポイントの両方を含め、消費者が企業と接触する可能性のあるすべてのタッチポイントが含まれる。本明細書で言及されるタッチポイントには、例えばポイント・オブ・セール(point-of-sale)、顧客サービス、マーケティング等が含まれる。実施形態は、検索可能なプロファイルを可能にするために、システムを通してデータ起源のトレーサビリティを維持する。また、CRE250は、データ要素のすべての入力、オペレーション及びアクセスに関する監査ログを維持することもできる。CRE250はまた、管理者又は「データスチュワード」が、システムの挙動を完全に制御し、データ品質を監視し、必要に応じてデータを修正することを可能にする。
【0056】
従来のシステムはまた、異なる時間スケールのデータを統合し、異なるソースのデータにアクセスし、データを比較し、それを調和させるという問題にも直面する。本明細書で提示される実施形態は、これらの問題を解決する。CRE250は、ソーシャルメディア・アプリケーションと統合して、消費者の活動を可視化し、それによって、異なる消費者のタッチポイントを提供することができる。システムは、あるイベントが以前の消費者によって生成されたのか、新しい消費者によって生成されたのかを決定するために、すべての入ってくるイベントの完全に統合されたビューを提供する。消費者の統合されたビューは、消費者に関するデータを調和させたので、消費者の完全な分析を可能にする。これとは対照的に、従来のシステムでは、消費者データの断片しか扱えなかった。例えば
図7に示されるように、消費者のサマンサ・スミスは、コマース・クラウドを介して商品を購入し、サービス・クラウドを介して、購入した製品についてのサービスを要求し、コミュニティクラウドを介してセルフ・サービスを実施し、マーケティング・クラウドを介して更なる商品を販売することができる。加えて、Samantha Smithは、企業のTwitter(登録商標)アカウントにTwitterメッセージを送信することができ、また、企業に関連する他の第三者アプリケーションも使用することができる。これらのタッチポイントの各々は、Samantha Smithに関するデータを有するが、そのデータは別個のシステムに分散され、分離されている。さらに、Samantha Smithは、異なるタッチポイントのために、Sam Smith等の異なる名前や異なる電子メールアドレスを使用していることがある。
図7に図示されるように、「Customer 360 via CRE(CREによるCustomer 360)」は、すべてのタッチポイントからのデータを調和させ、Samantha Smithのマスターレコードを作成することによって、消費者のSamantha Smithについて統一されたビューを提供する。さらに、CREは、テナントレコード・リンケージ、デジタルアイデンティティ・リンケージ及び第三者アイデンティティ・リンケージのような、データが来た場所のレコードを保持することによって、データ起源を提供する。顧客レコード調和の更なる詳細及び例は、2018年3月29日に出願された米国特許出願第15/940,419号及び2018年3月29日に出願された米国特許出願第15/940,448号に見出すことができ、それらの両方とも、参照によってそれぞれの全体が本明細書に組み込まれる。
【0057】
消費者の調和されたデータの統一されたビューは、将来のサービスとマーケティングについて消費者の挙動を分析することができる。例えば顧客は、企業のTwitter(登録商標)をツイートしたり、企業に関連するFacebook(登録商標)の投稿を作成したり、企業の広告が掲載されているウェブサイトを閲覧したり、企業の店舗を訪問したり、企業にリンクされている洗濯機/乾燥機のようなモノのインターネット(IOT)デバイスを使用したりすることがある。さらに、データの起源は、プライバシー問題を引き起こすことなく、電子メールのような消費者データをマーケティング又は他の目的に使用することができるかどうかの判断を可能にする。
【0058】
CREアーキテクチャ
図3に移ると、データソース300はデータ獲得を表す。データソース300は、コマース・クラウド218、マーケティング・クラウド216又は第三者システム258のような任意のデータソースを含むことができる。データソース300からのデータは、データソースのすべてから、イベントバスを介してCRE250にリアルタイムで流れることができる。
【0059】
ストリームプロセッサ302は、入ってくるデータ・ストリーム及び出て行くストリーミングデータストリームを処理する。ストリーミングデータはすべて、内部ストリームプロセッサ302で処理される。ストリームプロセッサ302は、データの起源及び監査能力を提供する監査ハンドラ304を含む。メトリクスハンドラ306は、例えば新規顧客がどのくらいの数か、更新がどのくらいの数か等といった動作メトリクスを提供する。イベントハンドラ308は、流入するストリーミングデータを監視し、データをカノニカルフォーマットに変換する。換言すれば、イベントハンドラ308は、正しいコンテキストフォーマットで処理できるように、入力及び出力データのデータ構造を変換する。データマッピング及び変換の例は、2018年7月17日出願の米国特許出願第16/037,435号に見出され、これは、参照によってその全体が本明細書に組み込まれる。
【0060】
監査ハンドラ304は、更新に対して動作するかどうかを決定するためのオペレーションを実行することができる。例えば新しいイベントがトリガされると、監査ハンドラ304は、発生した特定の変更を識別して記録し、更新を処理のために後の段階に転送するかどうかを決定することができる。これにより、監査ハンドラ304は、ストリーミングデータに関連付けられるコンテキスト情報に基づいて、ストリーミングデータが追加の処理を必要とするかどうかを判断する。一実施形態では、監査ハンドラ304は、この決定に関連付けられる情報又はコンテキスト情報をダウンストリームに送ることができる。
【0061】
変換ルールは、ストリームプロセッサが取り込んだイベントに関するカノニカル情報によって定義され得る。イベントがEMP234からストリームプロセッサ302に到達すると、テナント又はイベントに関する他のメタデータのようなコンテキスト情報は、監査ハンドラ304が論理的決定を行うことを可能にする。そのような決定は、たとえイベントを取り込む前であっても、データがどのように到着するかについての情報を予測することができる。そのような論理情報は、ストリームプロセッサ302によって適用される変換ルールを決定することができる。
【0062】
特定の実施形態では、監査ハンドラ304によって取り込まれるデータは、データが単一又は複数のデータソースからデータが取り込まれるとき、異なる形状又は内容を有してよい。例えばストリームプロセッサ302は、国フィールド(country field)を有するデータを取り込むことがあり、この場合、国フィールドは、異なるデータ・タイプ又はコンテンツを有してよい。監査ハンドラ304は、テナントに関するメタデータ又は他のコンテキスト情報に基づいて、データに関する論理的決定を行うことができる。データには変換ルールを適用してもよい。したがって、外部カスタマイズ顧客開発に依存する代わりに、データが取り込まれて、最終的にCREエンジン314に向けられるときに、メタデータを活用して適切な変換ルールを適用することができる。
【0063】
変更パブリッシャ310は、顧客のマスタープロファイルに対する更新をEMPバス234にパブリッシュする。例えばリンク又は電子メールアドレスがプロファイルに追加される場合、更新は、EMPバス234上でその顧客にサブスクライブしている誰にも送信される。データバッファ312は、ストリームプロセッサ302とCREエンジン314との間のデータをバッファする。
【0064】
CREエンジン314は、入力データが正規化されるデータ準備モジュール316を含む。例えばデータのソースによっては、アドレス又は電話番号が誤ったフォーマットであったり、不完全であったりする可能性がある。また、データ準備モジュール316は、例えば欠落している可能性のある地域コード又は国コードを追加することによってデータを補充する。マッチングモジュール318は、各レコードについて、既存のマスタープロファイルへの接続があるかどうかを判断する。例えばサービス・クラウドからのサービスレコードに関連付けられている人物を、ゲストチェックアウト・コマースレコードに関連付けられている人物とマッチングすることができる。したがって、マッチングモジュール318は、分離されたレコードを接続するエッジを作成する。
【0065】
CREエンジン314は、個々の消費者に向けられた関連する異なるデータソースから、異なる消費者データレコードを受け取り、関連付けることができる。マッチングモジュール318は、異なるデータソースから受け取った消費者レコードを標準フォーマットにフォーマットし、少なくとも1つの変換ルールに基づいて、その消費者データを既存のレコードとマッチングする。さらに、CREエンジン314は、フォーマットされたデータ及び個々の消費者に関連付けられる既存のレコードを使用して、そのような方法で消費者のためのマスターレコードを作成することができる。
【0066】
図7に関して上述したように、異なるソースにおけるSamantha Smithのための異なるレコードは、マッチングモジュールによって接続されてもよい。複数のレコードから1つのレコードを作成するように、マッチングルールが構成されて最適化される。マッチングモジュール318は、基準の構成可能なセットを使用して、カノニカルデータモデル内のマッチングレコードを決定する。UIの実施形態は、管理者がマッチングルールをセットアップして構成することを可能にする。マッチングルールは、基準(criteria)と、マッチングに使用できる条件(condition)の組合せとで構成される。データマッピングは、管理者が、顧客データとカノニカルフォーマットとの間のフィールドタイプにおける不一致を解決するコードを書くことを可能にすることができる。
【0067】
解決モジュール320は、レコード間の接続を分析して、どのレコードをクラスタ化すべきかを決定する。調和モジュール322は、異なるレコードのクラスタを使用してマスターレコードを作成する。また、マスタープロファイル内の特定の値の構成、例えばある人物についての所望の電子メールアドレスの構成も可能である。例えば
図7の「Customer 360 via CRE」レコードは、例えばコマース・クラウド、セールス・クラウド、第三者ソース等からの他のレコードを使用して、調和モジュール322によって作成される。複数のマッチがある場合は、データ調和のための異なるルールを一次及び二次タイブレーカー・ルール(tiebreaker rules)とともに入力することができる。
【0068】
CRE制御プレーン324は、CREシステムの部分間のデータフローのオーケストレーション(orchestration)及びシステムの特定の部分で問題が発生した場合のエラー処理を管理する。バッチ・オーケストレーションモジュール326は、すべてのファイルが正しい位置にあり、処理リソースが利用可能であることを確実にすることによって、バッチ処理を監督し、処理が実施されたときに通知を提供する。ストリーミング・オーケストレーションモジュール328は、CRE 250が正しい企業メッセージングプラットフォーム(Enterprise Messaging Platform)チャネルを聞いており、正しいチャネルにパブリッシングを行っていることを確実にする。障害回復(failure recovery)モジュール330は、システム内の障害を管理し、障害時に別のデータセンター内のリソースを割り当てることができる。システムワイド・オペレーション(System wide ops)モジュール332は、システムのソフトウェア・コンポーネントを開始及び停止する。一例では、CRE制御プレーン324はまた、弾性インフラストラクチャにおいてハードウェア容量のプロビジョニングを行うこともできる。
【0069】
顧客ハブ334は、監査データ、メトリクスデータ及びレコードリンケージを含むすべてのマスタープロファイルが格納される場所である。顧客ハブ334はまた、プロファイルに使用され得るデータの要素、例えばコマース・クラウド又はサービス・クラウドから入ってくるリンケージ又は顧客連絡先データを格納する。
【0070】
CREデータ336は、CRE API338を含む。CRE API338は、データスチュワードシップモジュール340を含む。データスチュワードシップモジュール340は、顧客又は管理者がマスターレコードを編集又は削除することを可能にする。例えばGDPRのようなプライバシー法の遵守のために、消費者が自身の情報を削除したい場合、データスチュワードシップモジュールを使用して、顧客ハブ334内の消費者のレコードを削除することができる。また、データスチュワードシップモジュール340は、監査及びメトリクスデータに対するユーザの可視性を与える。データスチュワードシップのためのUIは、レコードがまだ流れてきているかどうか、どのような速度で流れてきているか、どのくらいのレコードがエラーを発生しているか、どのような方法論(例えばファジーマッチングや正確なマッチング)がレコードとマッチングするために使用されているか等の情報を提供することができる。また、データスチュワードシップモジュール340は、顧客がプロファイルに対してクエリを実行し、プロファイル内のデータのソースを決定することを可能にする。例えばデータスチュワードシップモジュール340は、他のフィールドの中でも特に、入ってくる要求の優先レベル、要求のタイプ及び要求者に基づいて、ユーザがユーザインタフェースを介してデータを管理することを可能にする。ユーザインタフェースは、要求者からのメモとともに「プライバシー削除」のような要求タイプを表示することができる。さらに、データスチュワードシップモジュール340は、ユーザがフラグ付きレコードを単一のプロファイルレコードにマージすることを可能にする。データスチュワードシップモジュール340は、ユーザが、その中に含まれるデータに基づくレコードの検索を実行することを可能にする。
【0071】
CREエクスポートモジュール342は、データ分析のため、そして外部使用のために顧客ハブ334から大きなデータセットを移動させるために使用される。CRE検索モジュール344は、顧客ハブ334への同期アクセスを提供する。例えばCRE検索モジュール344は、顧客がマスタープロファイルの候補リストを検索することを可能にする。また、リアルタイムクエリやルックアップも可能である。管理者が顧客ハブ334からのデータをウェブページ上に置きたい場合、ウェブページをレンダリングするために、CRE検索モジュールを使用してクエリを実行する。また、CREデータ336は、DFS CREコネクタ346を介してDFS262から来るクエリに対する検索結果も提供する。上述のように、DFS262はテナントにわたって及びCRMシステム全体にわたってクエリする。
【0072】
顧客ハブ334を含むことに加えて、Hbase348は、構成データ350、メトリクスデータ352及び監査データ354を含む。HBaseは、顧客ハブのストレージレイヤとして使用されるNoSQL技術とすることができる。構成データ350は、CREエンジン314で使用されるようなデータ準備、マッチング、解決及び調和のためのルールを格納する。メトリクスデータ352は、メトリクスハンドラ306から受け取ったデータを格納する。監査データ354は、監査データを格納する。
【0073】
セットアップモジュール356は、クラウド関連サービスのためのUIアプリケーションである。レポーティングモジュール358は、顧客が決定を行うのを助けるために、システムの動作ステータスを提供する。レポーティングモジュール358は、マスター消費者プロファイルが、顧客が望む方法で構築されていることを、顧客に決定させる。レポーティングモジュール358はまた、システムがどのように動作しているかについてのフィードバックも提供する。外部ローディング分析視覚化(External loading analytics visualization)モジュール360は、顧客が、彼らの好ましいフォーマットで、例えばグラフ又はチャートとして、データをエクスポートして視覚化することを可能にする。
【0074】
FileForce(登録商標)362は、バッチ出力364及びバッチ入力366のためのファイルを格納する。バッチ入力366は、CREエンジン314によってストリームプロセッサ302からのストリーミングデータとマージすることができる、顧客について以前に格納されたすべてのデータを含む。バッチ出力364は、CREエンジン314から受け取られた、洗練された顧客データ(refined customer data)である。バッチ入力366及びバッチ出力364内のデータは、「csv」フォーマットで格納されてよい。
【0075】
本明細書で開示されているソフトウェアモジュールのうちの1つ以上は、コンテナ化されたソフトウェアを利用することができることが理解されよう。コンテナ化されたソフトウェアモジュールは、複数の開発者からのソフトウェアを同じマシン上で動作させることを可能にする。同一の識別番号を有する特定の要素は、図示を容易にするために、複数の図で異なる場所に示されていることが理解されよう。しかし、これらは同じ要素である。
【0076】
コンピュータシステム実装
様々な実施形態は、
図4に図示されるコンピュータシステム400のような1つ以上の周知のコンピュータシステムを使用して実装されてよい。1つ以上のコンピュータシステム400を使用して、例えば本明細書で説明された実施形態のいずれか、並びにそれらの組合せ及び副次的組合せを実装してよい。
【0077】
コンピュータシステム400は、プロセッサ404のような1つ以上のプロセッサ(中央処理ユニット又はCPUとも呼ばれる)を含んでもよい。プロセッサ404は、通信インフラストラクチャ又はバス406に接続されてよい。
【0078】
コンピュータシステム400はまた、モニタ、キーボード、ポインティングデバイス等のユーザ入力/出力デバイス403も含んでよい。ユーザ入力/出力デバイス403は、ユーザ入力/出力インタフェース402を介して通信インフラストラクチャ406と通信することができる。
【0079】
プロセッサ404の1つ以上は、グラフィックス処理ユニット(GPU)であってもよい。一実施形態では、GPUは、数学的集約アプリケーションを処理するように設計された専用の電子回路であるプロセッサであってもよい。GPUは、コンピュータ・グラフィックス・アプリケーション、画像、ビデオ等に共通の数学的集約データのような、データの大きなブロックの並列処理に効率的な並列構造を有してもよい。
【0080】
コンピュータシステム400はまた、ランダムアクセスメモリ(RAM)のようなメイン(又は一次)メモリ408を含んでもよい。メインメモリ408は、キャッシュの1つ以上のレベルを含んでもよい。メインメモリ408は、その中に制御ロジック(すなわち、コンピュータソフトウェア)及び/又はデータを格納しておくことができる。
【0081】
コンピュータシステム400はまた、1つ以上の二次ストレージデバイス又はメモリ410も含んでよい。二次メモリ410は、例えばハードディスクドライブ412又は取り外し可能ストレージデバイス又はドライブ414を含むことができる。取り外し可能ストレージドライブ414は、フロッピーディスクドライブ、磁気テープドライブ、コンパクトディスクドライブ、光ストレージデバイス、テープバックアップデバイス又は任意の他のストレージデバイス/ドライブであってもよい。
【0082】
取り外し可能ストレージドライブ414は、取り外し可能ストレージユニット418と対話することができる。取り外し可能ストレージユニット418は、その上にコンピュータソフトウェア(制御ロジック)又はデータを記憶した、コンピュータ使用可能又は読み取り可能なストレージデバイスを含んでもよい。取り外し可能ストレージユニット418は、フロッピーディスク、磁気テープ、コンパクトディスク、DVD、光ストレージディスク又は任意の他のコンピュータデータストレージデバイスであってよい。取り外し可能ストレージドライブ414は、取り外し可能ストレージユニット418との間で読み取り又は書き込みを行うことができる。
【0083】
二次メモリ410は、コンピュータプログラムあるいは他の命令又はデータがコンピュータシステム400によってアクセスされることを可能にする他の手段、デバイス、コンポーネント、機器又は他のアプローチを含んでもよい。そのような手段、デバイス、コンポーネント、機器又は他のアプローチは、例えば取り外し可能ストレージユニット422及びインタフェース420を含んでもよい。取り外し可能ストレージユニット422及びインタフェース420の例は、プログラムカートリッジ及びカートリッジインタフェース(ビデオゲームデバイス内で見られるもの等)、取り外し可能メモリチップ(EPROM又はPROM等)及び関連ソケット、メモリスティック及びUSBポート、メモリカード及び関連メモリカードスロット又は他の取り外し可能ストレージユニット及び関連インタフェースを含んでもよい。
【0084】
コンピュータシステム400は、通信又はネットワークインタフェース424を更に含むことができる。通信インタフェース424は、コンピュータシステム400が、(参照番号428によって個々に、かつ、集合的に参照される)外部デバイス、外部ネットワーク、外部エンティティ等の任意の組合せと通信して対話することを可能にし得る。例えば通信インタフェース424は、コンピュータシステム400が通信経路426を介して外部又はリモートデバイス428と通信することを可能にしてよい。通信経路426は、有線又は無線(又はそれらの組合せ)であってもよく、LAN、WAN、インターネット等の任意の組合せを含んでもよい。制御ロジック又はデータは、通信経路426を介してコンピュータシステム400との間で送信されてよい。
【0085】
コンピュータシステム400は、いくつかの非限定的な例を挙げると、パーソナル・デジタル・アシスタント(PDA)、デスクトップ・ワークステーション、ラップトップ又はノートブックコンピュータ、ネットブック、タブレット、スマートフォン、スマート・ウォッチ又は他のウェアラブル、アプライアンス、モノのインターネット(Internet-of-Things)の一部又は組み込みシステム、あるいはそれらの任意の組合せのいずれかとすることもできる。
【0086】
コンピュータシステム400は、任意の配信パラダイムを通して任意のアプリケーション又はデータにアクセスするかホストする、クライアント又はサーバであってよく、限定ではないが:リモート又は分散クラウド・コンピューティング・ソリューション;ローカル又はオンプレミス(on-premises)ソフトウェア(「オンプレミス」クラウド・ベースのソリューション);「アズ・ア・サービス(as a service)」モデル(例えばコンテンツ・アズ・ア・サービス(CaaS)、デジタルコンテンツ・アズ・ア・サービス(DCaaS)、ソフトウェア・アズ・ア・サービス(SaaS)、管理ソフトウェア・アズ・ア・サービス(MSaaS)、プラットフォーム・アズ・ア・サービス(PaaaS)、デスクトップ・アズ・ア・サービス(DaaS)、フレームワーク(FaaS)、バックエンド・アズ・ア・サービス(BaaS)、モバイルバックエンド・アズ・ア・サービス(MBaaS)、インフラストラクチャ・アズ・ア・サービス(IaaS);又は上記の例又は他のサービス又は配信パラダイムの任意の組合せを含むハイブリッド・モデルを含む。
【0087】
コンピュータシステム400における任意の適用可能なデータ構造、ファイル・フォーマット及びスキーマは、JavaScript(登録商標) Object Notification(JSON)、XML(Extensible Markup Language)、YAML(Yet Another Markup Language)、XHTML(Extensible Hypertext Markup Language)、WML(Wireless Markup Language)、MessagePack、XUL(XML User Interface Language)又は任意の他の機能的に類似した表現を単独で又は組合せで含むが、これらに限定されない規格から導出されてよい。あるいは、専用のデータ構造、フォーマット又はスキーマが排他的に、あるいは既知の又はオープンな規格との組合せで使用されてもよい。
【0088】
いくつかの実施形態において、その上に記憶された制御ロジック(ソフトウェア)を有する、有形の非一時的なコンピュータ使用可能又は読取可能な媒体を含む、有形の非一時的な装置又は製品は、本明細書において、コンピュータプログラム製品又はプログラムストレージデバイスと称されることもある。これは、コンピュータシステム400、メインメモリ408、二次メモリ410及び取り外し可能ストレージユニット418及び422、並びに上記のいずれかの組合せを具体化する有形の製品が含まれるが、これらに限定されない。そのような制御ロジックは、1つ以上のデータ処理デバイス(コンピュータシステム400等)によって実行されるとき、本明細書で記載されるように、そのようなデータ処理デバイスを動作させることができる。
【0089】
本開示に含まれる教示に基づいて、
図4に示されるもの以外のデータ処理デバイス、コンピュータシステム又はコンピュータ・アーキテクチャを用いて、本開示の実施形態をどのように作製し、使用するかは、当業者に明らかであろう。特に、実施形態は、本明細書に記載されているもの以外のソフトウェア、ハードウェア及び/又はオペレーティングシステムの実装で動作することができる。
【0090】
結論
詳細な説明のセクションは、他のセクションではなく、クレームを解釈するために使用されるように意図されていることが理解されよう。他のセクションは、本発明者によって考慮される、すべてではないが1つ以上の例示の実施形態を説明することができ、したがって、本開示又は添付の特許請求の範囲をいかなるようにも限定するようには意図されていない。
【0091】
本開示は、例示的な分野及び用途の例示的な実施形態を記載しているが、本開示はそれに限定されないことを理解されたい。他の実施形態及びそれに対する修正が可能であり、本開示の範囲及び精神内にある。例えば本段落の一般性を制限することなく、実施形態は、図面に図示されるか、本明細書で説明されるソフトウェア、ハードウェア、ファームウェア又はエンティティに限定されない。さらに、実施形態(本明細書で明示的に説明されているか否かにかかわらず)は、本明細書で説明される実施例を超える分野及び用途に対して有意な有用性を有する。
【0092】
本明細書では、特定の機能の実施及びそれらの関係を例示する機能的構築ブロックを用いて、実施形態を説明した。これらの機能的構成要素の境界は、説明の便宜上、本明細書中で任意に定義されている。特定の機能と関係(又はその均等物)が適切に実施される限り、別の境界を定義することができる。また、代替の実施形態は、本明細書で説明されるものとは異なる順序を使用して、機能ブロック、ステップ、動作、方法等を実行することができる。
【0093】
本明細書において、「一実施形態」、「ある実施形態」、「例示的な実施形態」又は類似のフレーズへの言及は、説明された実施形態が特定の特徴、構造又は特性を含むことができるが、すべての実施形態が必ずしも特定の特徴、構造又は特性を含まない可能性があることを示す。そのようなフレーズは、必ずしも同一の実施形態を指していない。さらに、特定の特徴、構造又は特性がある実施形態に関連して説明されるとき、このような特徴、構造又は特性を、本明細書に明示的に記載又は説明されているか否かにかかわらず、他の実施形態に組み込むことは当業者の知識の範囲内であろう。さらに、いくつかの実施形態は、「結合された(coupled)」及び「接続された(connected)」という表現をそれらの派生語とともに使用して説明される可能性がある。これらの用語は、必ずしも互いに同義語として意図されているわけではない。例えばいくつかの実施形態は、2つ以上の要素が互いに直接的に物理的又は電気的に接触していることを示すために、「接続された」又は「結合された」という用語を使用して説明されることができる。しかしながら、用語「結合された」は、2つ以上の要素が互いに直接接触していないが、依然として相互に協働又は相互作用していることも意味する可能性がある。
【0094】
本開示の広さ及び範囲は、上述の例示的な実施形態のいずれによっても制限されるべきではなく、以下の特許請求の範囲及びそれらの均等物に従ってのみ定義されるべきである。