225 lines
8.0 KiB
JSON
225 lines
8.0 KiB
JSON
{
|
|
"database": {
|
|
"name": "customer360_retail_db",
|
|
"collections": [
|
|
{
|
|
"name": "customers",
|
|
"fields": {
|
|
"_id": "ObjectId",
|
|
"customer_id": "String",
|
|
"first_name": "String",
|
|
"last_name": "String",
|
|
"email": "String",
|
|
"phone": "String",
|
|
"date_of_birth": "Date",
|
|
"gender": "String",
|
|
"registration_date": "Date",
|
|
"customer_segment": "String",
|
|
"preferences": "Array",
|
|
"address": {
|
|
"street": "String",
|
|
"city": "String",
|
|
"state": "String",
|
|
"zipcode": "String",
|
|
"country": "String"
|
|
},
|
|
"opt_in_marketing": "Boolean",
|
|
"created_at": "Date",
|
|
"updated_at": "Date"
|
|
},
|
|
"indexes": [
|
|
{"customer_id": 1, "unique": true},
|
|
{"email": 1, "unique": true},
|
|
{"phone": 1},
|
|
{"customer_segment": 1}
|
|
]
|
|
},
|
|
{
|
|
"name": "transactions",
|
|
"fields": {
|
|
"_id": "ObjectId",
|
|
"transaction_id": "String",
|
|
"customer_id": "String",
|
|
"transaction_date": "Date",
|
|
"items_purchased": [
|
|
{
|
|
"product_id": "String",
|
|
"product_name": "String",
|
|
"category": "String",
|
|
"quantity": "Int",
|
|
"price": "Double"
|
|
}
|
|
],
|
|
"payment_method": "String",
|
|
"total_amount": "Double",
|
|
"store_id": "String",
|
|
"channel": "String",
|
|
"created_at": "Date"
|
|
},
|
|
"indexes": [
|
|
{"transaction_id": 1, "unique": true},
|
|
{"customer_id": 1},
|
|
{"transaction_date": -1},
|
|
{"store_id": 1}
|
|
]
|
|
},
|
|
{
|
|
"name": "products",
|
|
"fields": {
|
|
"_id": "ObjectId",
|
|
"product_id": "String",
|
|
"name": "String",
|
|
"description": "String",
|
|
"category": "String",
|
|
"sub_category": "String",
|
|
"brand": "String",
|
|
"price": "Double",
|
|
"available": "Boolean",
|
|
"created_at": "Date",
|
|
"updated_at": "Date"
|
|
},
|
|
"indexes": [
|
|
{"product_id": 1, "unique": true},
|
|
{"category": 1},
|
|
{"brand": 1},
|
|
{"available": 1}
|
|
]
|
|
},
|
|
{
|
|
"name": "web_activities",
|
|
"fields": {
|
|
"_id": "ObjectId",
|
|
"activity_id": "String",
|
|
"customer_id": "String",
|
|
"session_id": "String",
|
|
"activity_type": "String",
|
|
"page_url": "String",
|
|
"referrer": "String",
|
|
"device": {
|
|
"device_type": "String",
|
|
"browser": "String",
|
|
"os": "String"
|
|
},
|
|
"activity_timestamp": "Date",
|
|
"metadata": "Object",
|
|
"created_at": "Date"
|
|
},
|
|
"indexes": [
|
|
{"activity_id": 1, "unique": true},
|
|
{"customer_id": 1},
|
|
{"session_id": 1},
|
|
{"activity_type": 1},
|
|
{"activity_timestamp": -1}
|
|
]
|
|
},
|
|
{
|
|
"name": "marketing_campaigns",
|
|
"fields": {
|
|
"_id": "ObjectId",
|
|
"campaign_id": "String",
|
|
"name": "String",
|
|
"description": "String",
|
|
"start_date": "Date",
|
|
"end_date": "Date",
|
|
"channels": "Array",
|
|
"segment_targets": "Array",
|
|
"status": "String",
|
|
"budget": "Double",
|
|
"spent": "Double",
|
|
"performance_metrics": "Object",
|
|
"created_at": "Date",
|
|
"updated_at": "Date"
|
|
},
|
|
"indexes": [
|
|
{"campaign_id": 1, "unique": true},
|
|
{"name": 1},
|
|
{"status": 1},
|
|
{"start_date": -1}
|
|
]
|
|
},
|
|
{
|
|
"name": "support_interactions",
|
|
"fields": {
|
|
"_id": "ObjectId",
|
|
"interaction_id": "String",
|
|
"customer_id": "String",
|
|
"date": "Date",
|
|
"channel": "String",
|
|
"support_agent": "String",
|
|
"reason": "String",
|
|
"resolution_status": "String",
|
|
"resolution_time_minutes": "Int",
|
|
"notes": "String",
|
|
"created_at": "Date"
|
|
},
|
|
"indexes": [
|
|
{"interaction_id": 1, "unique": true},
|
|
{"customer_id": 1},
|
|
{"date": -1},
|
|
{"resolution_status": 1}
|
|
]
|
|
},
|
|
{
|
|
"name": "loyalty_program",
|
|
"fields": {
|
|
"_id": "ObjectId",
|
|
"customer_id": "String",
|
|
"loyalty_number": "String",
|
|
"points": "Int",
|
|
"membership_tier": "String",
|
|
"enrolled_date": "Date",
|
|
"last_activity_date": "Date",
|
|
"rewards_redeemed": "Array",
|
|
"created_at": "Date",
|
|
"updated_at": "Date"
|
|
},
|
|
"indexes": [
|
|
{"customer_id": 1, "unique": true},
|
|
{"loyalty_number": 1, "unique": true},
|
|
{"membership_tier": 1}
|
|
]
|
|
},
|
|
{
|
|
"name": "analytics_reports",
|
|
"fields": {
|
|
"_id": "ObjectId",
|
|
"report_id": "String",
|
|
"generated_date": "Date",
|
|
"report_type": "String",
|
|
"time_period": {
|
|
"start_date": "Date",
|
|
"end_date": "Date"
|
|
},
|
|
"parameters": "Object",
|
|
"result": "Object",
|
|
"generated_by": "String",
|
|
"created_at": "Date"
|
|
},
|
|
"indexes": [
|
|
{"report_id": 1, "unique": true},
|
|
{"report_type": 1},
|
|
{"generated_date": -1}
|
|
]
|
|
},
|
|
{
|
|
"name": "users",
|
|
"fields": {
|
|
"_id": "ObjectId",
|
|
"user_id": "String",
|
|
"name": "String",
|
|
"email": "String",
|
|
"password_hash": "String",
|
|
"role": "String",
|
|
"permissions": "Array",
|
|
"created_at": "Date"
|
|
},
|
|
"indexes": [
|
|
{"user_id": 1, "unique": true},
|
|
{"email": 1, "unique": true},
|
|
{"role": 1}
|
|
]
|
|
}
|
|
]
|
|
}
|
|
}
|