{
  "domain": "wedding_planning",
  "databases": [
    {
      "table_name": "wedding_event",
      "description": "Stores core wedding event information including couple details, date, venue, and theme",
      "schema": {
        "columns": [
          {
            "name": "wedding_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the wedding event",
            "optional": false
          },
          {
            "name": "bride_name",
            "type": "VARCHAR(100)",
            "description": "Full name of the bride",
            "optional": false
          },
          {
            "name": "groom_name",
            "type": "VARCHAR(100)",
            "description": "Full name of the groom",
            "optional": false
          },
          {
            "name": "wedding_date",
            "type": "DATETIME",
            "description": "Date and time of the wedding ceremony",
            "optional": false
          },
          {
            "name": "venue_name",
            "type": "VARCHAR(200)",
            "description": "Name of the wedding venue",
            "optional": false
          },
          {
            "name": "wedding_theme",
            "type": "VARCHAR(100)",
            "description": "Theme or style of the wedding",
            "optional": true
          },
          {
            "name": "estimated_guest_count",
            "type": "INTEGER",
            "description": "Estimated number of guests attending",
            "optional": true
          },
          {
            "name": "creation_timestamp",
            "type": "DATETIME",
            "description": "Timestamp when the wedding event was created",
            "optional": false
          }
        ],
        "primary_key": "wedding_id"
      }
    },
    {
      "table_name": "guest",
      "description": "Stores guest information including contact details, RSVP status, and meal preferences",
      "schema": {
        "columns": [
          {
            "name": "guest_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the guest",
            "optional": false
          },
          {
            "name": "wedding_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the wedding event",
            "optional": false,
            "references": "wedding_event.wedding_id"
          },
          {
            "name": "guest_name",
            "type": "VARCHAR(100)",
            "description": "Full name of the guest",
            "optional": false
          },
          {
            "name": "email",
            "type": "VARCHAR(100)",
            "description": "Email address of the guest",
            "optional": false
          },
          {
            "name": "phone_number",
            "type": "VARCHAR(20)",
            "description": "Phone number of the guest",
            "optional": true
          },
          {
            "name": "meal_preference",
            "type": "VARCHAR(20)",
            "description": "Dietary preference for the meal",
            "optional": true,
            "enum": [
              "vegetarian",
              "vegan",
              "gluten_free",
              "no_restriction",
              "kosher",
              "halal"
            ]
          },
          {
            "name": "plus_one_allowed",
            "type": "BOOLEAN",
            "description": "Whether the guest is allowed to bring a plus one",
            "optional": true
          },
          {
            "name": "rsvp_status",
            "type": "VARCHAR(20)",
            "description": "RSVP response status",
            "default": "pending",
            "optional": false,
            "enum": [
              "attending",
              "declined",
              "pending",
              "maybe"
            ]
          },
          {
            "name": "response_date",
            "type": "DATETIME",
            "description": "Date when the RSVP was received",
            "optional": true
          },
          {
            "name": "added_timestamp",
            "type": "DATETIME",
            "description": "Timestamp when the guest was added",
            "optional": false
          }
        ],
        "primary_key": "guest_id"
      }
    },
    {
      "table_name": "vendor_contract",
      "description": "Stores vendor contract information including service details, pricing, and payment status",
      "schema": {
        "columns": [
          {
            "name": "contract_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the vendor contract",
            "optional": false
          },
          {
            "name": "wedding_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the wedding event",
            "optional": false,
            "references": "wedding_event.wedding_id"
          },
          {
            "name": "vendor_name",
            "type": "VARCHAR(200)",
            "description": "Name of the vendor company",
            "optional": false
          },
          {
            "name": "vendor_type",
            "type": "VARCHAR(50)",
            "description": "Type of service provided by the vendor",
            "optional": false,
            "enum": [
              "florist",
              "photographer",
              "caterer",
              "dj",
              "videographer",
              "decorator",
              "baker",
              "planner",
              "transportation",
              "entertainment"
            ]
          },
          {
            "name": "contract_amount",
            "type": "DECIMAL(10,2)",
            "description": "Total contract amount in dollars",
            "optional": false
          },
          {
            "name": "deposit_amount",
            "type": "DECIMAL(10,2)",
            "description": "Deposit amount required in dollars",
            "optional": true
          },
          {
            "name": "service_date",
            "type": "DATETIME",
            "description": "Date when the service will be provided",
            "optional": true
          },
          {
            "name": "contact_person",
            "type": "VARCHAR(100)",
            "description": "Name of the contact person at the vendor",
            "optional": true
          },
          {
            "name": "contact_phone",
            "type": "VARCHAR(20)",
            "description": "Phone number of the vendor contact",
            "optional": true
          },
          {
            "name": "payment_status",
            "type": "VARCHAR(20)",
            "description": "Current payment status",
            "default": "not_paid",
            "optional": false,
            "enum": [
              "not_paid",
              "deposit_paid",
              "partially_paid",
              "fully_paid",
              "overdue"
            ]
          },
          {
            "name": "amount_paid",
            "type": "DECIMAL(10,2)",
            "description": "Amount that has been paid in dollars",
            "default": "0.00",
            "optional": false
          },
          {
            "name": "payment_date",
            "type": "DATETIME",
            "description": "Date when the last payment was made",
            "optional": true
          },
          {
            "name": "creation_timestamp",
            "type": "DATETIME",
            "description": "Timestamp when the contract was created",
            "optional": false
          }
        ],
        "primary_key": "contract_id"
      }
    },
    {
      "table_name": "budget_category",
      "description": "Stores budget categories with allocated amounts for wedding expenses",
      "schema": {
        "columns": [
          {
            "name": "category_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the budget category",
            "optional": false
          },
          {
            "name": "wedding_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the wedding event",
            "optional": false,
            "references": "wedding_event.wedding_id"
          },
          {
            "name": "category_name",
            "type": "VARCHAR(50)",
            "description": "Name of the budget category",
            "optional": false,
            "enum": [
              "venue",
              "catering",
              "photography",
              "flowers",
              "music",
              "attire",
              "decorations",
              "invitations",
              "transportation",
              "honeymoon",
              "gifts",
              "miscellaneous"
            ]
          },
          {
            "name": "allocated_amount",
            "type": "DECIMAL(10,2)",
            "description": "Amount allocated for this category in dollars",
            "optional": false
          },
          {
            "name": "notes",
            "type": "TEXT",
            "description": "Additional notes about this budget category",
            "optional": true
          },
          {
            "name": "creation_timestamp",
            "type": "DATETIME",
            "description": "Timestamp when the category was created",
            "optional": false
          }
        ],
        "primary_key": "category_id"
      }
    },
    {
      "table_name": "expense",
      "description": "Stores actual expenses recorded against budget categories",
      "schema": {
        "columns": [
          {
            "name": "expense_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the expense",
            "optional": false
          },
          {
            "name": "wedding_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the wedding event",
            "optional": false,
            "references": "wedding_event.wedding_id"
          },
          {
            "name": "category_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the budget category",
            "optional": false,
            "references": "budget_category.category_id"
          },
          {
            "name": "expense_description",
            "type": "VARCHAR(500)",
            "description": "Description of the expense",
            "optional": false
          },
          {
            "name": "amount",
            "type": "DECIMAL(10,2)",
            "description": "Amount of the expense in dollars",
            "optional": false
          },
          {
            "name": "expense_date",
            "type": "DATETIME",
            "description": "Date when the expense was incurred",
            "optional": false
          },
          {
            "name": "payment_method",
            "type": "VARCHAR(20)",
            "description": "Method used for payment",
            "optional": true,
            "enum": [
              "cash",
              "credit_card",
              "debit_card",
              "check",
              "bank_transfer",
              "online_payment"
            ]
          }
        ],
        "primary_key": "expense_id"
      }
    },
    {
      "table_name": "task",
      "description": "Stores wedding planning tasks with deadlines, assignments, and status tracking",
      "schema": {
        "columns": [
          {
            "name": "task_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the task",
            "optional": false
          },
          {
            "name": "wedding_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the wedding event",
            "optional": false,
            "references": "wedding_event.wedding_id"
          },
          {
            "name": "task_title",
            "type": "VARCHAR(200)",
            "description": "Title of the task",
            "optional": false
          },
          {
            "name": "task_description",
            "type": "TEXT",
            "description": "Detailed description of the task",
            "optional": true
          },
          {
            "name": "due_date",
            "type": "DATETIME",
            "description": "Deadline for the task",
            "optional": false
          },
          {
            "name": "priority",
            "type": "VARCHAR(20)",
            "description": "Priority level of the task",
            "optional": false,
            "enum": [
              "low",
              "medium",
              "high",
              "urgent"
            ]
          },
          {
            "name": "assigned_to",
            "type": "VARCHAR(100)",
            "description": "Name of the person assigned to the task",
            "optional": true
          },
          {
            "name": "category",
            "type": "VARCHAR(50)",
            "description": "Category of the task",
            "optional": true,
            "enum": [
              "venue",
              "vendors",
              "guests",
              "attire",
              "decorations",
              "invitations",
              "logistics",
              "legal",
              "other"
            ]
          },
          {
            "name": "status",
            "type": "VARCHAR(20)",
            "description": "Current status of the task",
            "default": "not_started",
            "optional": false,
            "enum": [
              "not_started",
              "in_progress",
              "completed",
              "cancelled",
              "on_hold"
            ]
          },
          {
            "name": "completion_date",
            "type": "DATETIME",
            "description": "Date when the task was completed",
            "optional": true
          },
          {
            "name": "notes",
            "type": "TEXT",
            "description": "Additional notes about the task",
            "optional": true
          },
          {
            "name": "creation_timestamp",
            "type": "DATETIME",
            "description": "Timestamp when the task was created",
            "optional": false
          }
        ],
        "primary_key": "task_id"
      }
    },
    {
      "table_name": "seating_table",
      "description": "Stores seating arrangement tables with capacity and location information",
      "schema": {
        "columns": [
          {
            "name": "table_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the table",
            "optional": false
          },
          {
            "name": "wedding_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the wedding event",
            "optional": false,
            "references": "wedding_event.wedding_id"
          },
          {
            "name": "table_number",
            "type": "VARCHAR(50)",
            "description": "Number or identifier of the table",
            "optional": false
          },
          {
            "name": "table_capacity",
            "type": "INTEGER",
            "description": "Maximum number of guests that can be seated at the table",
            "optional": false
          },
          {
            "name": "table_location",
            "type": "VARCHAR(200)",
            "description": "Location or section of the table in the venue",
            "optional": true
          },
          {
            "name": "table_type",
            "type": "VARCHAR(20)",
            "description": "Type or shape of the table",
            "optional": true,
            "enum": [
              "round",
              "rectangular",
              "square",
              "banquet",
              "head_table"
            ]
          },
          {
            "name": "creation_timestamp",
            "type": "DATETIME",
            "description": "Timestamp when the table was created",
            "optional": false
          }
        ],
        "primary_key": "table_id"
      }
    },
    {
      "table_name": "guest_seating_assignment",
      "description": "Stores guest-to-table seating assignments",
      "schema": {
        "columns": [
          {
            "name": "assignment_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the seating assignment",
            "optional": false
          },
          {
            "name": "wedding_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the wedding event",
            "optional": false,
            "references": "wedding_event.wedding_id"
          },
          {
            "name": "guest_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the guest",
            "optional": false,
            "references": "guest.guest_id"
          },
          {
            "name": "table_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the table",
            "optional": false,
            "references": "seating_table.table_id"
          },
          {
            "name": "seat_number",
            "type": "INTEGER",
            "description": "Specific seat number at the table",
            "optional": true
          }
        ],
        "primary_key": "assignment_id"
      }
    },
    {
      "table_name": "timeline_event",
      "description": "Stores timeline events for the wedding day schedule",
      "schema": {
        "columns": [
          {
            "name": "timeline_event_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the timeline event",
            "optional": false
          },
          {
            "name": "wedding_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the wedding event",
            "optional": false,
            "references": "wedding_event.wedding_id"
          },
          {
            "name": "event_name",
            "type": "VARCHAR(200)",
            "description": "Name of the timeline event",
            "optional": false
          },
          {
            "name": "start_time",
            "type": "DATETIME",
            "description": "Start time of the event",
            "optional": false
          },
          {
            "name": "end_time",
            "type": "DATETIME",
            "description": "End time of the event",
            "optional": false
          },
          {
            "name": "location",
            "type": "VARCHAR(200)",
            "description": "Location where the event takes place",
            "optional": true
          },
          {
            "name": "description",
            "type": "TEXT",
            "description": "Detailed description of the event",
            "optional": true
          },
          {
            "name": "responsible_person",
            "type": "VARCHAR(100)",
            "description": "Person responsible for this event",
            "optional": true
          },
          {
            "name": "creation_timestamp",
            "type": "DATETIME",
            "description": "Timestamp when the event was created",
            "optional": false
          }
        ],
        "primary_key": "timeline_event_id"
      }
    },
    {
      "table_name": "invitation",
      "description": "Stores invitation delivery records and status tracking",
      "schema": {
        "columns": [
          {
            "name": "invitation_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the invitation",
            "optional": false
          },
          {
            "name": "wedding_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the wedding event",
            "optional": false,
            "references": "wedding_event.wedding_id"
          },
          {
            "name": "guest_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the guest",
            "optional": false,
            "references": "guest.guest_id"
          },
          {
            "name": "delivery_method",
            "type": "VARCHAR(20)",
            "description": "Method used to deliver the invitation",
            "optional": false,
            "enum": [
              "email",
              "postal_mail",
              "hand_delivery",
              "digital_app"
            ]
          },
          {
            "name": "invitation_message",
            "type": "TEXT",
            "description": "Custom message included in the invitation",
            "optional": true
          },
          {
            "name": "send_date",
            "type": "DATETIME",
            "description": "Date when the invitation is sent",
            "optional": true
          },
          {
            "name": "delivery_status",
            "type": "VARCHAR(20)",
            "description": "Status of the invitation delivery",
            "optional": false
          },
          {
            "name": "sent_timestamp",
            "type": "DATETIME",
            "description": "Timestamp when the invitation was sent",
            "optional": false
          }
        ],
        "primary_key": "invitation_id"
      }
    },
    {
      "table_name": "gift_registry",
      "description": "Stores gift registry information for the wedding",
      "schema": {
        "columns": [
          {
            "name": "registry_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the gift registry",
            "optional": false
          },
          {
            "name": "wedding_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the wedding event",
            "optional": false,
            "references": "wedding_event.wedding_id"
          },
          {
            "name": "registry_name",
            "type": "VARCHAR(200)",
            "description": "Name of the gift registry",
            "optional": false
          },
          {
            "name": "registry_url",
            "type": "VARCHAR(500)",
            "description": "URL link to the online registry",
            "optional": true
          },
          {
            "name": "store_name",
            "type": "VARCHAR(200)",
            "description": "Name of the store hosting the registry",
            "optional": true
          },
          {
            "name": "creation_timestamp",
            "type": "DATETIME",
            "description": "Timestamp when the registry was created",
            "optional": false
          }
        ],
        "primary_key": "registry_id"
      }
    },
    {
      "table_name": "gift_item",
      "description": "Stores gift items in the wedding registry with purchase tracking",
      "schema": {
        "columns": [
          {
            "name": "item_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the gift item",
            "optional": false
          },
          {
            "name": "wedding_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the wedding event",
            "optional": false,
            "references": "wedding_event.wedding_id"
          },
          {
            "name": "registry_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the gift registry",
            "optional": false,
            "references": "gift_registry.registry_id"
          },
          {
            "name": "item_name",
            "type": "VARCHAR(200)",
            "description": "Name of the gift item",
            "optional": false
          },
          {
            "name": "item_description",
            "type": "TEXT",
            "description": "Description of the gift item",
            "optional": true
          },
          {
            "name": "price",
            "type": "DECIMAL(10,2)",
            "description": "Price of the item in dollars",
            "optional": false
          },
          {
            "name": "quantity_desired",
            "type": "INTEGER",
            "description": "Number of this item desired",
            "optional": false
          },
          {
            "name": "quantity_purchased",
            "type": "INTEGER",
            "description": "Number of items purchased",
            "default": "0",
            "optional": false
          },
          {
            "name": "category",
            "type": "VARCHAR(50)",
            "description": "Category of the gift item",
            "optional": true,
            "enum": [
              "kitchen",
              "bedroom",
              "bathroom",
              "dining",
              "home_decor",
              "electronics",
              "outdoor",
              "experience",
              "cash_fund"
            ]
          },
          {
            "name": "purchased_by",
            "type": "VARCHAR(100)",
            "description": "Name of the guest who purchased the item",
            "optional": true
          },
          {
            "name": "purchase_date",
            "type": "DATETIME",
            "description": "Date when the item was purchased",
            "optional": true
          },
          {
            "name": "creation_timestamp",
            "type": "DATETIME",
            "description": "Timestamp when the item was added",
            "optional": false
          }
        ],
        "primary_key": "item_id"
      }
    },
    {
      "table_name": "photo_album",
      "description": "Stores photo albums for wedding photos with metadata",
      "schema": {
        "columns": [
          {
            "name": "album_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the photo album",
            "optional": false
          },
          {
            "name": "wedding_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the wedding event",
            "optional": false,
            "references": "wedding_event.wedding_id"
          },
          {
            "name": "album_name",
            "type": "VARCHAR(200)",
            "description": "Name of the photo album",
            "optional": false
          },
          {
            "name": "album_description",
            "type": "TEXT",
            "description": "Description of the album",
            "optional": true
          },
          {
            "name": "photographer_name",
            "type": "VARCHAR(200)",
            "description": "Name of the photographer",
            "optional": true
          },
          {
            "name": "album_date",
            "type": "DATETIME",
            "description": "Date when photos were taken",
            "optional": true
          },
          {
            "name": "creation_timestamp",
            "type": "DATETIME",
            "description": "Timestamp when the album was created",
            "optional": false
          }
        ],
        "primary_key": "album_id"
      }
    },
    {
      "table_name": "photo",
      "description": "Stores individual photos in wedding albums with metadata and tags",
      "schema": {
        "columns": [
          {
            "name": "photo_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the photo",
            "optional": false
          },
          {
            "name": "wedding_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the wedding event",
            "optional": false,
            "references": "wedding_event.wedding_id"
          },
          {
            "name": "album_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the photo album",
            "optional": false,
            "references": "photo_album.album_id"
          },
          {
            "name": "photo_url",
            "type": "VARCHAR(500)",
            "description": "URL or path to the photo file",
            "optional": false
          },
          {
            "name": "photo_caption",
            "type": "TEXT",
            "description": "Caption for the photo",
            "optional": true
          },
          {
            "name": "photo_timestamp",
            "type": "DATETIME",
            "description": "Timestamp when the photo was taken",
            "optional": true
          },
          {
            "name": "tags",
            "type": "TEXT",
            "description": "Tags or keywords for the photo stored as comma-separated values",
            "optional": true
          },
          {
            "name": "upload_timestamp",
            "type": "DATETIME",
            "description": "Timestamp when the photo was uploaded",
            "optional": false
          }
        ],
        "primary_key": "photo_id"
      }
    },
    {
      "table_name": "notification",
      "description": "Stores reminder notifications sent to guests or vendors",
      "schema": {
        "columns": [
          {
            "name": "notification_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the notification",
            "optional": false
          },
          {
            "name": "wedding_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the wedding event",
            "optional": false,
            "references": "wedding_event.wedding_id"
          },
          {
            "name": "recipient_type",
            "type": "VARCHAR(20)",
            "description": "Type of recipient for the reminder",
            "optional": false,
            "enum": [
              "guest",
              "vendor",
              "wedding_party",
              "all_guests"
            ]
          },
          {
            "name": "recipient_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier of the recipient",
            "optional": true
          },
          {
            "name": "reminder_subject",
            "type": "VARCHAR(200)",
            "description": "Subject of the reminder",
            "optional": false
          },
          {
            "name": "reminder_message",
            "type": "TEXT",
            "description": "Content of the reminder message",
            "optional": false
          },
          {
            "name": "delivery_method",
            "type": "VARCHAR(20)",
            "description": "Method to deliver the reminder",
            "optional": false,
            "enum": [
              "email",
              "sms",
              "push_notification",
              "phone_call"
            ]
          },
          {
            "name": "scheduled_send_time",
            "type": "DATETIME",
            "description": "Scheduled time to send the reminder",
            "optional": true
          },
          {
            "name": "delivery_status",
            "type": "VARCHAR(20)",
            "description": "Status of the notification delivery",
            "optional": false
          }
        ],
        "primary_key": "notification_id"
      }
    },
    {
      "table_name": "wedding_website",
      "description": "Stores wedding website information with customization options",
      "schema": {
        "columns": [
          {
            "name": "website_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the wedding website",
            "optional": false
          },
          {
            "name": "wedding_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the wedding event",
            "optional": false,
            "references": "wedding_event.wedding_id"
          },
          {
            "name": "website_url",
            "type": "VARCHAR(500)",
            "description": "Custom URL for the wedding website",
            "optional": false
          },
          {
            "name": "theme_name",
            "type": "VARCHAR(50)",
            "description": "Theme or design style for the website",
            "optional": true,
            "enum": [
              "classic",
              "modern",
              "rustic",
              "elegant",
              "beach",
              "garden",
              "vintage"
            ]
          },
          {
            "name": "welcome_message",
            "type": "TEXT",
            "description": "Welcome message displayed on the website",
            "optional": true
          },
          {
            "name": "include_rsvp_form",
            "type": "BOOLEAN",
            "description": "Whether to include an RSVP form on the website",
            "optional": true
          },
          {
            "name": "include_registry_link",
            "type": "BOOLEAN",
            "description": "Whether to include a link to the gift registry",
            "optional": true
          },
          {
            "name": "creation_timestamp",
            "type": "DATETIME",
            "description": "Timestamp when the website was created",
            "optional": false
          }
        ],
        "primary_key": "website_id"
      }
    },
    {
      "table_name": "music_playlist",
      "description": "Stores music playlists for different parts of the wedding",
      "schema": {
        "columns": [
          {
            "name": "playlist_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the music playlist",
            "optional": false
          },
          {
            "name": "wedding_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the wedding event",
            "optional": false,
            "references": "wedding_event.wedding_id"
          },
          {
            "name": "playlist_name",
            "type": "VARCHAR(200)",
            "description": "Name of the music playlist",
            "optional": false
          },
          {
            "name": "event_segment",
            "type": "VARCHAR(50)",
            "description": "Wedding segment for this playlist",
            "optional": false,
            "enum": [
              "pre_ceremony",
              "processional",
              "ceremony",
              "recessional",
              "cocktail_hour",
              "reception_entrance",
              "first_dance",
              "dinner",
              "dancing",
              "last_song"
            ]
          },
          {
            "name": "total_duration_minutes",
            "type": "INTEGER",
            "description": "Total duration of the playlist in minutes",
            "optional": true
          },
          {
            "name": "creation_timestamp",
            "type": "DATETIME",
            "description": "Timestamp when the playlist was created",
            "optional": false
          }
        ],
        "primary_key": "playlist_id"
      }
    },
    {
      "table_name": "song",
      "description": "Stores songs in wedding music playlists",
      "schema": {
        "columns": [
          {
            "name": "song_id",
            "type": "VARCHAR(10)",
            "description": "Unique identifier for the song",
            "optional": false
          },
          {
            "name": "wedding_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the wedding event",
            "optional": false,
            "references": "wedding_event.wedding_id"
          },
          {
            "name": "playlist_id",
            "type": "VARCHAR(10)",
            "description": "Reference to the music playlist",
            "optional": false,
            "references": "music_playlist.playlist_id"
          },
          {
            "name": "song_title",
            "type": "VARCHAR(200)",
            "description": "Title of the song",
            "optional": false
          },
          {
            "name": "artist_name",
            "type": "VARCHAR(200)",
            "description": "Name of the artist or composer",
            "optional": false
          },
          {
            "name": "duration_seconds",
            "type": "INTEGER",
            "description": "Duration of the song in seconds",
            "optional": true
          },
          {
            "name": "play_order",
            "type": "INTEGER",
            "description": "Order in which the song should play in the playlist",
            "optional": true
          },
          {
            "name": "added_timestamp",
            "type": "DATETIME",
            "description": "Timestamp when the song was added",
            "optional": false
          }
        ],
        "primary_key": "song_id"
      }
    }
  ],
  "tools": [
    {
      "name": "get_seating_chart",
      "description": "Retrieve the complete seating chart for the wedding reception",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "seating_management",
      "action_category": "data_retrieval",
      "pre_condition": "Wedding event must exist",
      "post_condition": "Seating chart is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          }
        },
        "required": [
          "wedding_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "tables": {
            "description": "List of all tables with assigned guests",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "table_id": "TABLE005",
                  "table_number": "Table 5",
                  "guests": [
                    "Sarah Williams",
                    "John Doe"
                  ]
                }
              ]
            ]
          },
          "total_tables": {
            "description": "Total number of tables",
            "type": "integer",
            "examples": [
              20
            ]
          },
          "total_seated_guests": {
            "description": "Total number of guests with table assignments",
            "type": "integer",
            "examples": [
              145
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "seating_table",
        "guest_seating_assignment",
        "guest"
      ]
    },
    {
      "name": "generate_thank_you_list",
      "description": "Generate a list of guests who need to receive thank you notes based on gifts received",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "gift_registry_management",
      "action_category": "content_generation",
      "pre_condition": "Wedding event must exist with gift records",
      "post_condition": "Thank you list is generated",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          }
        },
        "required": [
          "wedding_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "thank_you_list": {
            "description": "List of guests with gift details for thank you notes",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "guest_name": "Sarah Williams",
                  "gift_description": "Kitchen Stand Mixer",
                  "thank_you_sent": false
                }
              ]
            ]
          },
          "total_thank_you_notes_needed": {
            "description": "Total number of thank you notes to send",
            "type": "integer",
            "examples": [
              85
            ]
          },
          "notes_sent": {
            "description": "Number of thank you notes already sent",
            "type": "integer",
            "examples": [
              35
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "gift_item",
        "guest"
      ]
    },
    {
      "name": "generate_vendor_payment_schedule",
      "description": "Generate a payment schedule for all vendors based on contract terms",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "vendor_management",
      "action_category": "content_generation",
      "pre_condition": "Wedding event must exist with vendor contracts",
      "post_condition": "Payment schedule is generated",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          }
        },
        "required": [
          "wedding_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "payment_schedule": {
            "description": "List of payment milestones for all vendors",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "vendor_name": "Elegant Flowers Co",
                  "payment_date": "2025-05-15 23:59:59",
                  "amount": 1250.0,
                  "payment_type": "final_payment"
                }
              ]
            ]
          },
          "total_upcoming_payments": {
            "description": "Total amount of upcoming payments in dollars",
            "type": "number",
            "examples": [
              15000.0
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "vendor_contract"
      ]
    },
    {
      "name": "add_gift_item",
      "description": "Add a gift item to the wedding registry",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "gift_registry_management",
      "action_category": "data_creation",
      "pre_condition": "Gift registry must exist",
      "post_condition": "Gift item is added to registry",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "registry_id": {
            "description": "Unique identifier of the gift registry",
            "type": "string",
            "examples": [
              "REGISTRY001"
            ]
          },
          "item_name": {
            "description": "Name of the gift item",
            "type": "string",
            "examples": [
              "Kitchen Stand Mixer"
            ]
          },
          "item_description": {
            "description": "Description of the gift item",
            "type": "string",
            "examples": [
              "Professional 5-quart stand mixer with multiple attachments"
            ]
          },
          "price": {
            "description": "Price of the item in dollars",
            "type": "number",
            "examples": [
              299.99
            ]
          },
          "quantity_desired": {
            "description": "Number of this item desired",
            "type": "integer",
            "examples": [
              1
            ]
          },
          "category": {
            "description": "Category of the gift item",
            "type": "string",
            "enum": [
              "kitchen",
              "bedroom",
              "bathroom",
              "dining",
              "home_decor",
              "electronics",
              "outdoor",
              "experience",
              "cash_fund"
            ],
            "examples": [
              "kitchen"
            ]
          }
        },
        "required": [
          "wedding_id",
          "registry_id",
          "item_name",
          "price",
          "quantity_desired"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "item_id": {
            "description": "Unique identifier for the gift item",
            "type": "string",
            "examples": [
              "ITEM001"
            ]
          },
          "creation_timestamp": {
            "description": "Timestamp when the item was added in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-12-01 19:30:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "gift_item"
      ]
    },
    {
      "name": "get_budget_summary",
      "description": "Retrieve a summary of the wedding budget including all categories and expenses",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "budget_management",
      "action_category": "data_retrieval",
      "pre_condition": "Wedding event must exist",
      "post_condition": "Budget summary is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          }
        },
        "required": [
          "wedding_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "total_budget": {
            "description": "Total allocated budget in dollars",
            "type": "number",
            "examples": [
              50000.0
            ]
          },
          "total_spent": {
            "description": "Total amount spent in dollars",
            "type": "number",
            "examples": [
              22000.0
            ]
          },
          "remaining_budget": {
            "description": "Remaining budget in dollars",
            "type": "number",
            "examples": [
              28000.0
            ]
          },
          "categories": {
            "description": "List of budget categories with details",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "category_name": "catering",
                  "allocated": 8000.0,
                  "spent": 2000.0
                }
              ]
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "budget_category",
        "expense"
      ]
    },
    {
      "name": "generate_gift_registry",
      "description": "Generate a gift registry with items and their details",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "gift_registry_management",
      "action_category": "data_creation",
      "pre_condition": "Wedding event must exist",
      "post_condition": "Gift registry is created",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "registry_name": {
            "description": "Name of the gift registry",
            "type": "string",
            "examples": [
              "Emily and Michael's Wedding Registry"
            ]
          },
          "registry_url": {
            "description": "URL link to the online registry",
            "type": "string",
            "examples": [
              "https://registry.example.com/emily-michael"
            ]
          },
          "store_name": {
            "description": "Name of the store hosting the registry",
            "type": "string",
            "examples": [
              "HomeGoods Plus"
            ]
          }
        },
        "required": [
          "wedding_id",
          "registry_name"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "registry_id": {
            "description": "Unique identifier for the gift registry",
            "type": "string",
            "examples": [
              "REGISTRY001"
            ]
          },
          "creation_timestamp": {
            "description": "Timestamp when the registry was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-12-01 19:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "gift_registry"
      ]
    },
    {
      "name": "create_wedding_website",
      "description": "Create a wedding website with details and customization options",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "website_management",
      "action_category": "data_creation",
      "pre_condition": "Wedding event must exist",
      "post_condition": "Wedding website is created",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "website_url": {
            "description": "Custom URL for the wedding website",
            "type": "string",
            "examples": [
              "https://emilyandmichael.wedding"
            ]
          },
          "theme_name": {
            "description": "Theme or design style for the website",
            "type": "string",
            "enum": [
              "classic",
              "modern",
              "rustic",
              "elegant",
              "beach",
              "garden",
              "vintage"
            ],
            "examples": [
              "rustic"
            ]
          },
          "welcome_message": {
            "description": "Welcome message displayed on the website",
            "type": "string",
            "examples": [
              "Welcome to our wedding celebration!"
            ]
          },
          "include_rsvp_form": {
            "description": "Whether to include an RSVP form on the website",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "include_registry_link": {
            "description": "Whether to include a link to the gift registry",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        },
        "required": [
          "wedding_id",
          "website_url"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "website_id": {
            "description": "Unique identifier for the wedding website",
            "type": "string",
            "examples": [
              "WEBSITE001"
            ]
          },
          "website_url": {
            "description": "URL of the created wedding website",
            "type": "string",
            "examples": [
              "https://emilyandmichael.wedding"
            ]
          },
          "creation_timestamp": {
            "description": "Timestamp when the website was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-12-01 20:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "wedding_website"
      ]
    },
    {
      "name": "track_invitation_responses",
      "description": "Track and retrieve invitation response statistics for the wedding",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "invitation_management",
      "action_category": "data_analysis",
      "pre_condition": "Wedding event must exist with sent invitations",
      "post_condition": "Invitation response statistics are returned",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          }
        },
        "required": [
          "wedding_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "total_invitations_sent": {
            "description": "Total number of invitations sent",
            "type": "integer",
            "examples": [
              150
            ]
          },
          "responses_received": {
            "description": "Number of responses received",
            "type": "integer",
            "examples": [
              120
            ]
          },
          "confirmed_count": {
            "description": "Number of guests who confirmed attendance",
            "type": "integer",
            "examples": [
              105
            ]
          },
          "declined_count": {
            "description": "Number of guests who declined",
            "type": "integer",
            "examples": [
              15
            ]
          },
          "pending_count": {
            "description": "Number of guests who haven't responded",
            "type": "integer",
            "examples": [
              30
            ]
          },
          "response_rate": {
            "description": "Percentage of guests who have responded",
            "type": "number",
            "examples": [
              80.0
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "invitation",
        "guest"
      ]
    },
    {
      "name": "assign_guest_to_table",
      "description": "Assign a guest to a specific table in the seating arrangement",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "seating_management",
      "action_category": "data_modification",
      "pre_condition": "Guest and table must exist",
      "post_condition": "Guest is assigned to table",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "guest_id": {
            "description": "Unique identifier of the guest",
            "type": "string",
            "examples": [
              "GUEST001"
            ]
          },
          "table_id": {
            "description": "Unique identifier of the table",
            "type": "string",
            "examples": [
              "TABLE005"
            ]
          },
          "seat_number": {
            "description": "Specific seat number at the table",
            "type": "integer",
            "examples": [
              3
            ]
          }
        },
        "required": [
          "wedding_id",
          "guest_id",
          "table_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether the assignment was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "remaining_capacity": {
            "description": "Remaining capacity at the table",
            "type": "integer",
            "examples": [
              5
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "guest_seating_assignment",
        "seating_table"
      ]
    },
    {
      "name": "record_expense",
      "description": "Record an actual expense against a budget category",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "budget_management",
      "action_category": "data_creation",
      "pre_condition": "Budget category must exist",
      "post_condition": "Expense is recorded",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "category_id": {
            "description": "Unique identifier of the budget category",
            "type": "string",
            "examples": [
              "BUDGET001"
            ]
          },
          "expense_description": {
            "description": "Description of the expense",
            "type": "string",
            "examples": [
              "Deposit for catering service"
            ]
          },
          "amount": {
            "description": "Amount of the expense in dollars",
            "type": "number",
            "examples": [
              2000.0
            ]
          },
          "expense_date": {
            "description": "Date when the expense was incurred in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-12-05 10:00:00"
            ]
          },
          "payment_method": {
            "description": "Method used for payment",
            "type": "string",
            "enum": [
              "cash",
              "credit_card",
              "debit_card",
              "check",
              "bank_transfer",
              "online_payment"
            ],
            "examples": [
              "credit_card"
            ]
          }
        },
        "required": [
          "wedding_id",
          "category_id",
          "expense_description",
          "amount",
          "expense_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "expense_id": {
            "description": "Unique identifier for the recorded expense",
            "type": "string",
            "examples": [
              "EXP001"
            ]
          },
          "remaining_budget": {
            "description": "Remaining budget for the category in dollars",
            "type": "number",
            "examples": [
              6000.0
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "expense",
        "budget_category"
      ]
    },
    {
      "name": "update_guest_rsvp_status",
      "description": "Update the RSVP status of a guest",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "guest_management",
      "action_category": "data_modification",
      "pre_condition": "Guest must exist in the wedding guest list",
      "post_condition": "Guest RSVP status is updated",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "guest_id": {
            "description": "Unique identifier of the guest",
            "type": "string",
            "examples": [
              "GUEST001"
            ]
          },
          "rsvp_status": {
            "description": "RSVP response status",
            "type": "string",
            "enum": [
              "attending",
              "declined",
              "pending",
              "maybe"
            ],
            "examples": [
              "attending"
            ]
          },
          "response_date": {
            "description": "Date when the RSVP was received in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-12-15 09:30:00"
            ]
          }
        },
        "required": [
          "wedding_id",
          "guest_id",
          "rsvp_status"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether the update was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "updated_status": {
            "description": "The new RSVP status",
            "type": "string",
            "examples": [
              "attending"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "guest"
      ]
    },
    {
      "name": "generate_emergency_contact_list",
      "description": "Generate an emergency contact list for the wedding day including all key vendors and participants",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "contact_management",
      "action_category": "content_generation",
      "pre_condition": "Wedding event must exist with vendor and participant information",
      "post_condition": "Emergency contact list is generated",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          }
        },
        "required": [
          "wedding_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "emergency_contacts": {
            "description": "List of emergency contacts with details",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "name": "Wedding Coordinator",
                  "role": "coordinator",
                  "phone": "+1-555-0100",
                  "backup_phone": "+1-555-0101"
                }
              ]
            ]
          },
          "venue_emergency_info": {
            "description": "Emergency information for the venue",
            "type": "object",
            "examples": [
              {
                "venue_name": "Grand Ballroom Hotel",
                "emergency_exit_locations": "East and West wings",
                "first_aid_location": "Front desk"
              }
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "vendor_contract",
        "wedding_event"
      ]
    },
    {
      "name": "create_seating_arrangement",
      "description": "Create a seating arrangement for the wedding reception with table assignments",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "seating_management",
      "action_category": "data_creation",
      "pre_condition": "Wedding event must exist",
      "post_condition": "Seating arrangement is created",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "table_number": {
            "description": "Number or identifier of the table",
            "type": "string",
            "examples": [
              "Table 5"
            ]
          },
          "table_capacity": {
            "description": "Maximum number of guests that can be seated at the table",
            "type": "integer",
            "examples": [
              8
            ]
          },
          "table_location": {
            "description": "Location or section of the table in the venue",
            "type": "string",
            "examples": [
              "East Wing near windows"
            ]
          },
          "table_type": {
            "description": "Type or shape of the table",
            "type": "string",
            "enum": [
              "round",
              "rectangular",
              "square",
              "banquet",
              "head_table"
            ],
            "examples": [
              "round"
            ]
          }
        },
        "required": [
          "wedding_id",
          "table_number",
          "table_capacity"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "table_id": {
            "description": "Unique identifier for the table",
            "type": "string",
            "examples": [
              "TABLE005"
            ]
          },
          "creation_timestamp": {
            "description": "Timestamp when the table was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-12-01 17:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "seating_table"
      ]
    },
    {
      "name": "create_budget_category",
      "description": "Create a budget category with allocated amount for wedding expenses",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "budget_management",
      "action_category": "data_creation",
      "pre_condition": "Wedding event must exist",
      "post_condition": "Budget category is created",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "category_name": {
            "description": "Name of the budget category",
            "type": "string",
            "enum": [
              "venue",
              "catering",
              "photography",
              "flowers",
              "music",
              "attire",
              "decorations",
              "invitations",
              "transportation",
              "honeymoon",
              "gifts",
              "miscellaneous"
            ],
            "examples": [
              "catering"
            ]
          },
          "allocated_amount": {
            "description": "Amount allocated for this category in dollars",
            "type": "number",
            "examples": [
              8000.0
            ]
          },
          "notes": {
            "description": "Additional notes about this budget category",
            "type": "string",
            "examples": [
              "Includes appetizers, main course, and dessert for 150 guests"
            ]
          }
        },
        "required": [
          "wedding_id",
          "category_name",
          "allocated_amount"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "category_id": {
            "description": "Unique identifier for the budget category",
            "type": "string",
            "examples": [
              "BUDGET001"
            ]
          },
          "creation_timestamp": {
            "description": "Timestamp when the category was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-12-01 15:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "budget_category"
      ]
    },
    {
      "name": "generate_rehearsal_schedule",
      "description": "Generate a schedule for the wedding rehearsal with all participants and activities",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "timeline_management",
      "action_category": "content_generation",
      "pre_condition": "Valid wedding date and rehearsal date must be provided",
      "post_condition": "Rehearsal schedule is generated",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_date": {
            "description": "Date of the wedding in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2025-06-15 14:00:00"
            ]
          },
          "rehearsal_date": {
            "description": "Date of the rehearsal in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2025-06-14 17:00:00"
            ]
          },
          "venue_name": {
            "description": "Name of the venue for the rehearsal",
            "type": "string",
            "examples": [
              "Grand Ballroom Hotel"
            ]
          },
          "wedding_party_size": {
            "description": "Number of people in the wedding party",
            "type": "integer",
            "examples": [
              12
            ]
          }
        },
        "required": [
          "wedding_date",
          "rehearsal_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "rehearsal_activities": {
            "description": "List of rehearsal activities with timing",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "activity": "Processional practice",
                  "start_time": "2025-06-14 17:00:00",
                  "duration_minutes": 30
                }
              ]
            ]
          },
          "total_duration_minutes": {
            "description": "Total duration of the rehearsal in minutes",
            "type": "integer",
            "examples": [
              120
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "get_wedding_details",
      "description": "Retrieve complete details of a wedding event by its identifier",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "event_management",
      "action_category": "data_retrieval",
      "pre_condition": "Wedding event must exist",
      "post_condition": "Wedding details are returned",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          }
        },
        "required": [
          "wedding_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "bride_name": {
            "description": "Full name of the bride",
            "type": "string",
            "examples": [
              "Emily Johnson"
            ]
          },
          "groom_name": {
            "description": "Full name of the groom",
            "type": "string",
            "examples": [
              "Michael Smith"
            ]
          },
          "wedding_date": {
            "description": "Date and time of the wedding in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2025-06-15 14:00:00"
            ]
          },
          "venue_name": {
            "description": "Name of the wedding venue",
            "type": "string",
            "examples": [
              "Grand Ballroom Hotel"
            ]
          },
          "wedding_theme": {
            "description": "Theme or style of the wedding",
            "type": "string",
            "examples": [
              "Rustic Garden"
            ]
          },
          "estimated_guest_count": {
            "description": "Estimated number of guests",
            "type": "integer",
            "examples": [
              150
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "wedding_event"
      ]
    },
    {
      "name": "send_reminder_notification",
      "description": "Send reminder notifications to guests or vendors about upcoming events or deadlines",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "notification_management",
      "action_category": "communication",
      "pre_condition": "Recipient must exist in the system",
      "post_condition": "Reminder notification is sent",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "recipient_type": {
            "description": "Type of recipient for the reminder",
            "type": "string",
            "enum": [
              "guest",
              "vendor",
              "wedding_party",
              "all_guests"
            ],
            "examples": [
              "guest"
            ]
          },
          "recipient_id": {
            "description": "Unique identifier of the recipient",
            "type": "string",
            "examples": [
              "GUEST001"
            ]
          },
          "reminder_subject": {
            "description": "Subject of the reminder",
            "type": "string",
            "examples": [
              "RSVP Deadline Approaching"
            ]
          },
          "reminder_message": {
            "description": "Content of the reminder message",
            "type": "string",
            "examples": [
              "Please remember to RSVP by January 15, 2025"
            ]
          },
          "delivery_method": {
            "description": "Method to deliver the reminder",
            "type": "string",
            "enum": [
              "email",
              "sms",
              "push_notification",
              "phone_call"
            ],
            "examples": [
              "email"
            ]
          },
          "scheduled_send_time": {
            "description": "Scheduled time to send the reminder in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2025-01-10 09:00:00"
            ]
          }
        },
        "required": [
          "wedding_id",
          "recipient_type",
          "reminder_subject",
          "reminder_message",
          "delivery_method"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "notification_id": {
            "description": "Unique identifier for the sent notification",
            "type": "string",
            "examples": [
              "NOTIF001"
            ]
          },
          "delivery_status": {
            "description": "Status of the notification delivery",
            "type": "string",
            "examples": [
              "scheduled"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "notification"
      ]
    },
    {
      "name": "calculate_task_completion_rate",
      "description": "Calculate the percentage of completed tasks for the wedding",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "task_management",
      "action_category": "data_analysis",
      "pre_condition": "Wedding event must exist with tasks",
      "post_condition": "Task completion rate is calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          }
        },
        "required": [
          "wedding_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "total_tasks": {
            "description": "Total number of tasks",
            "type": "integer",
            "examples": [
              25
            ]
          },
          "completed_tasks": {
            "description": "Number of completed tasks",
            "type": "integer",
            "examples": [
              15
            ]
          },
          "completion_rate": {
            "description": "Percentage of tasks completed",
            "type": "number",
            "examples": [
              60.0
            ]
          },
          "in_progress_tasks": {
            "description": "Number of tasks in progress",
            "type": "integer",
            "examples": [
              7
            ]
          },
          "not_started_tasks": {
            "description": "Number of tasks not started",
            "type": "integer",
            "examples": [
              3
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "task"
      ]
    },
    {
      "name": "send_invitation",
      "description": "Send a wedding invitation to a guest via specified delivery method",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "invitation_management",
      "action_category": "communication",
      "pre_condition": "Guest must exist in the wedding guest list",
      "post_condition": "Invitation is sent and delivery status is recorded",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "guest_id": {
            "description": "Unique identifier of the guest",
            "type": "string",
            "examples": [
              "GUEST001"
            ]
          },
          "delivery_method": {
            "description": "Method used to deliver the invitation",
            "type": "string",
            "enum": [
              "email",
              "postal_mail",
              "hand_delivery",
              "digital_app"
            ],
            "examples": [
              "email"
            ]
          },
          "invitation_message": {
            "description": "Custom message to include in the invitation",
            "type": "string",
            "examples": [
              "We joyfully invite you to celebrate our special day"
            ]
          },
          "send_date": {
            "description": "Date when the invitation is sent in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-12-15 09:00:00"
            ]
          }
        },
        "required": [
          "wedding_id",
          "guest_id",
          "delivery_method"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "invitation_id": {
            "description": "Unique identifier for the sent invitation",
            "type": "string",
            "examples": [
              "INV001"
            ]
          },
          "delivery_status": {
            "description": "Status of the invitation delivery",
            "type": "string",
            "examples": [
              "sent"
            ]
          },
          "sent_timestamp": {
            "description": "Timestamp when the invitation was sent in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-12-15 09:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "invitation"
      ]
    },
    {
      "name": "calculate_total_vendor_cost",
      "description": "Calculate the total cost of all vendors for a wedding",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "vendor_management",
      "action_category": "computation",
      "pre_condition": "Wedding event must exist",
      "post_condition": "Total vendor cost is calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          }
        },
        "required": [
          "wedding_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "total_contract_amount": {
            "description": "Total amount of all vendor contracts in dollars",
            "type": "number",
            "examples": [
              25000.0
            ]
          },
          "total_paid": {
            "description": "Total amount already paid to vendors in dollars",
            "type": "number",
            "examples": [
              10000.0
            ]
          },
          "total_remaining": {
            "description": "Total remaining balance for all vendors in dollars",
            "type": "number",
            "examples": [
              15000.0
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "vendor_contract"
      ]
    },
    {
      "name": "get_guest_list",
      "description": "Retrieve the complete list of guests for a wedding event",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "guest_management",
      "action_category": "data_retrieval",
      "pre_condition": "Wedding event must exist",
      "post_condition": "Guest list is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          }
        },
        "required": [
          "wedding_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "guests": {
            "description": "List of all guests for the wedding",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "guest_id": "GUEST001",
                  "guest_name": "Sarah Williams",
                  "rsvp_status": "pending"
                }
              ]
            ]
          },
          "total_count": {
            "description": "Total number of guests",
            "type": "integer",
            "examples": [
              150
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "guest"
      ]
    },
    {
      "name": "calculate_guest_meal_summary",
      "description": "Calculate the summary of meal preferences across all guests",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "guest_management",
      "action_category": "data_analysis",
      "pre_condition": "Wedding event must exist with guest meal preferences",
      "post_condition": "Meal preference summary is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          }
        },
        "required": [
          "wedding_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "meal_counts": {
            "description": "Count of each meal preference type",
            "type": "object",
            "examples": [
              {
                "vegetarian": 25,
                "vegan": 10,
                "gluten_free": 8,
                "no_restriction": 107
              }
            ]
          },
          "total_guests_with_preferences": {
            "description": "Total number of guests with meal preferences recorded",
            "type": "integer",
            "examples": [
              150
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "guest"
      ]
    },
    {
      "name": "get_tasks_by_deadline",
      "description": "Retrieve all tasks due within a specified date range",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "task_management",
      "action_category": "data_retrieval",
      "pre_condition": "Wedding event must exist",
      "post_condition": "Tasks within deadline range are returned",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "start_date": {
            "description": "Start date of the range in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-12-01 00:00:00"
            ]
          },
          "end_date": {
            "description": "End date of the range in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2025-01-31 23:59:59"
            ]
          }
        },
        "required": [
          "wedding_id",
          "start_date",
          "end_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "tasks": {
            "description": "List of tasks due within the specified range",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "task_id": "TASK001",
                  "task_title": "Book photographer",
                  "due_date": "2025-03-01 23:59:59"
                }
              ]
            ]
          },
          "task_count": {
            "description": "Number of tasks in the result",
            "type": "integer",
            "examples": [
              5
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "task"
      ]
    },
    {
      "name": "calculate_days_until_wedding",
      "description": "Calculate the number of days remaining until the wedding date",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "event_management",
      "action_category": "computation",
      "pre_condition": "Valid wedding date must be provided",
      "post_condition": "Number of days until wedding is calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_date": {
            "description": "Date of the wedding in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2025-06-15 14:00:00"
            ]
          },
          "current_date": {
            "description": "Current date for calculation in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-12-01 00:00:00"
            ]
          }
        },
        "required": [
          "wedding_date",
          "current_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "days_remaining": {
            "description": "Number of days until the wedding",
            "type": "integer",
            "examples": [
              196
            ]
          },
          "weeks_remaining": {
            "description": "Number of weeks until the wedding",
            "type": "integer",
            "examples": [
              28
            ]
          },
          "months_remaining": {
            "description": "Number of months until the wedding",
            "type": "integer",
            "examples": [
              6
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "GENERIC",
      "related_databases": []
    },
    {
      "name": "update_vendor_payment_status",
      "description": "Update the payment status for a vendor contract",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "vendor_management",
      "action_category": "data_modification",
      "pre_condition": "Vendor contract must exist",
      "post_condition": "Vendor payment status is updated",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "contract_id": {
            "description": "Unique identifier of the vendor contract",
            "type": "string",
            "examples": [
              "VENDOR001"
            ]
          },
          "payment_status": {
            "description": "Current payment status",
            "type": "string",
            "enum": [
              "not_paid",
              "deposit_paid",
              "partially_paid",
              "fully_paid",
              "overdue"
            ],
            "examples": [
              "deposit_paid"
            ]
          },
          "amount_paid": {
            "description": "Amount that has been paid in dollars",
            "type": "number",
            "examples": [
              500.0
            ]
          },
          "payment_date": {
            "description": "Date when the payment was made in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-12-10 16:00:00"
            ]
          }
        },
        "required": [
          "wedding_id",
          "contract_id",
          "payment_status",
          "amount_paid"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether the update was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "remaining_balance": {
            "description": "Remaining balance to be paid in dollars",
            "type": "number",
            "examples": [
              2000.0
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "vendor_contract"
      ]
    },
    {
      "name": "add_guest_to_wedding",
      "description": "Add a new guest to the wedding guest list with contact information and meal preferences",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "guest_management",
      "action_category": "data_creation",
      "pre_condition": "Wedding event must exist",
      "post_condition": "Guest is added to the wedding guest list",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "guest_name": {
            "description": "Full name of the guest",
            "type": "string",
            "examples": [
              "Sarah Williams"
            ]
          },
          "email": {
            "description": "Email address of the guest",
            "type": "string",
            "examples": [
              "sarah.williams@example.com"
            ]
          },
          "phone_number": {
            "description": "Phone number of the guest",
            "type": "string",
            "examples": [
              "+1-555-0123"
            ]
          },
          "meal_preference": {
            "description": "Dietary preference for the meal",
            "type": "string",
            "enum": [
              "vegetarian",
              "vegan",
              "gluten_free",
              "no_restriction",
              "kosher",
              "halal"
            ],
            "examples": [
              "vegetarian"
            ]
          },
          "plus_one_allowed": {
            "description": "Whether the guest is allowed to bring a plus one",
            "type": "boolean",
            "examples": [
              true
            ]
          }
        },
        "required": [
          "wedding_id",
          "guest_name",
          "email"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "guest_id": {
            "description": "Unique identifier for the added guest",
            "type": "string",
            "examples": [
              "GUEST001"
            ]
          },
          "added_timestamp": {
            "description": "Timestamp when the guest was added in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-12-01 11:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "guest"
      ]
    },
    {
      "name": "add_photo_to_album",
      "description": "Add a photo to a wedding album with metadata and tags",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "photo_management",
      "action_category": "data_creation",
      "pre_condition": "Photo album must exist",
      "post_condition": "Photo is added to album",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "album_id": {
            "description": "Unique identifier of the photo album",
            "type": "string",
            "examples": [
              "ALBUM001"
            ]
          },
          "photo_url": {
            "description": "URL or path to the photo file",
            "type": "string",
            "examples": [
              "https://photos.example.com/wedding/photo001.jpg"
            ]
          },
          "photo_caption": {
            "description": "Caption for the photo",
            "type": "string",
            "examples": [
              "First kiss as husband and wife"
            ]
          },
          "photo_timestamp": {
            "description": "Timestamp when the photo was taken in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2025-06-15 14:25:00"
            ]
          },
          "tags": {
            "description": "Tags or keywords for the photo",
            "type": "array",
            "items": {
              "type": "string"
            },
            "examples": [
              [
                "ceremony",
                "kiss",
                "bride",
                "groom"
              ]
            ]
          }
        },
        "required": [
          "wedding_id",
          "album_id",
          "photo_url"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "photo_id": {
            "description": "Unique identifier for the photo",
            "type": "string",
            "examples": [
              "PHOTO001"
            ]
          },
          "upload_timestamp": {
            "description": "Timestamp when the photo was uploaded in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2025-06-16 10:15:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "photo"
      ]
    },
    {
      "name": "get_wedding_timeline",
      "description": "Retrieve the complete timeline schedule for the wedding day",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "timeline_management",
      "action_category": "data_retrieval",
      "pre_condition": "Wedding event must exist",
      "post_condition": "Wedding timeline is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          }
        },
        "required": [
          "wedding_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "timeline_events": {
            "description": "List of all timeline events in chronological order",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "event_name": "Ceremony begins",
                  "start_time": "2025-06-15 14:00:00",
                  "end_time": "2025-06-15 14:30:00"
                }
              ]
            ]
          },
          "total_events": {
            "description": "Total number of timeline events",
            "type": "integer",
            "examples": [
              12
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "timeline_event"
      ]
    },
    {
      "name": "update_task_status",
      "description": "Update the completion status of a wedding planning task",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "task_management",
      "action_category": "data_modification",
      "pre_condition": "Task must exist",
      "post_condition": "Task status is updated",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "task_id": {
            "description": "Unique identifier of the task",
            "type": "string",
            "examples": [
              "TASK001"
            ]
          },
          "status": {
            "description": "Current status of the task",
            "type": "string",
            "enum": [
              "not_started",
              "in_progress",
              "completed",
              "cancelled",
              "on_hold"
            ],
            "examples": [
              "completed"
            ]
          },
          "completion_date": {
            "description": "Date when the task was completed in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-12-20 14:30:00"
            ]
          },
          "notes": {
            "description": "Additional notes about the task completion",
            "type": "string",
            "examples": [
              "Photographer booked successfully for June 15"
            ]
          }
        },
        "required": [
          "wedding_id",
          "task_id",
          "status"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether the update was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "updated_status": {
            "description": "The new task status",
            "type": "string",
            "examples": [
              "completed"
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "task"
      ]
    },
    {
      "name": "add_song_to_playlist",
      "description": "Add a song to a wedding music playlist",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "music_management",
      "action_category": "data_creation",
      "pre_condition": "Music playlist must exist",
      "post_condition": "Song is added to playlist",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "playlist_id": {
            "description": "Unique identifier of the music playlist",
            "type": "string",
            "examples": [
              "PLAYLIST001"
            ]
          },
          "song_title": {
            "description": "Title of the song",
            "type": "string",
            "examples": [
              "Canon in D"
            ]
          },
          "artist_name": {
            "description": "Name of the artist or composer",
            "type": "string",
            "examples": [
              "Johann Pachelbel"
            ]
          },
          "duration_seconds": {
            "description": "Duration of the song in seconds",
            "type": "integer",
            "examples": [
              300
            ]
          },
          "play_order": {
            "description": "Order in which the song should play in the playlist",
            "type": "integer",
            "examples": [
              1
            ]
          }
        },
        "required": [
          "wedding_id",
          "playlist_id",
          "song_title",
          "artist_name"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "song_id": {
            "description": "Unique identifier for the song in the playlist",
            "type": "string",
            "examples": [
              "SONG001"
            ]
          },
          "added_timestamp": {
            "description": "Timestamp when the song was added in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-12-01 21:15:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "song"
      ]
    },
    {
      "name": "create_wedding_event",
      "description": "Create a new wedding event with basic information including couple names, wedding date, venue, and theme",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "event_management",
      "action_category": "data_creation",
      "pre_condition": "Wedding date must be in the future",
      "post_condition": "Wedding event is created and assigned a unique identifier",
      "parameters": {
        "type": "object",
        "properties": {
          "bride_name": {
            "description": "Full name of the bride",
            "type": "string",
            "examples": [
              "Emily Johnson"
            ]
          },
          "groom_name": {
            "description": "Full name of the groom",
            "type": "string",
            "examples": [
              "Michael Smith"
            ]
          },
          "wedding_date": {
            "description": "Date and time of the wedding ceremony in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2025-06-15 14:00:00"
            ]
          },
          "venue_name": {
            "description": "Name of the wedding venue",
            "type": "string",
            "examples": [
              "Grand Ballroom Hotel"
            ]
          },
          "wedding_theme": {
            "description": "Theme or style of the wedding",
            "type": "string",
            "examples": [
              "Rustic Garden"
            ]
          },
          "estimated_guest_count": {
            "description": "Estimated number of guests attending",
            "type": "integer",
            "examples": [
              150
            ]
          }
        },
        "required": [
          "bride_name",
          "groom_name",
          "wedding_date",
          "venue_name"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier for the created wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "creation_timestamp": {
            "description": "Timestamp when the wedding event was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-12-01 10:30:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "wedding_event"
      ]
    },
    {
      "name": "get_vendor_list",
      "description": "Retrieve all vendors associated with a wedding event",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "vendor_management",
      "action_category": "data_retrieval",
      "pre_condition": "Wedding event must exist",
      "post_condition": "Vendor list is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          }
        },
        "required": [
          "wedding_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "vendors": {
            "description": "List of all vendors for the wedding",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "contract_id": "VENDOR001",
                  "vendor_name": "Elegant Flowers Co",
                  "vendor_type": "florist"
                }
              ]
            ]
          },
          "total_vendors": {
            "description": "Total number of vendors",
            "type": "integer",
            "examples": [
              8
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "vendor_contract"
      ]
    },
    {
      "name": "create_music_playlist",
      "description": "Create a music playlist for different parts of the wedding",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "music_management",
      "action_category": "data_creation",
      "pre_condition": "Wedding event must exist",
      "post_condition": "Music playlist is created",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "playlist_name": {
            "description": "Name of the music playlist",
            "type": "string",
            "examples": [
              "Ceremony Music"
            ]
          },
          "event_segment": {
            "description": "Wedding segment for this playlist",
            "type": "string",
            "enum": [
              "pre_ceremony",
              "processional",
              "ceremony",
              "recessional",
              "cocktail_hour",
              "reception_entrance",
              "first_dance",
              "dinner",
              "dancing",
              "last_song"
            ],
            "examples": [
              "processional"
            ]
          },
          "total_duration_minutes": {
            "description": "Total duration of the playlist in minutes",
            "type": "integer",
            "examples": [
              30
            ]
          }
        },
        "required": [
          "wedding_id",
          "playlist_name",
          "event_segment"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "playlist_id": {
            "description": "Unique identifier for the music playlist",
            "type": "string",
            "examples": [
              "PLAYLIST001"
            ]
          },
          "creation_timestamp": {
            "description": "Timestamp when the playlist was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-12-01 21:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "music_playlist"
      ]
    },
    {
      "name": "validate_seating_capacity",
      "description": "Validate that the seating arrangement can accommodate all confirmed guests",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "seating_management",
      "action_category": "validation",
      "pre_condition": "Wedding event must exist with seating arrangement",
      "post_condition": "Seating capacity validation result is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          }
        },
        "required": [
          "wedding_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "is_valid": {
            "description": "Indicates whether the seating capacity is sufficient",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "total_capacity": {
            "description": "Total seating capacity across all tables",
            "type": "integer",
            "examples": [
              160
            ]
          },
          "confirmed_count": {
            "description": "Number of confirmed guests",
            "type": "integer",
            "examples": [
              145
            ]
          },
          "available_seats": {
            "description": "Number of available seats",
            "type": "integer",
            "examples": [
              15
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "seating_table",
        "guest"
      ]
    },
    {
      "name": "calculate_total_confirmed_guests",
      "description": "Calculate the total number of guests who have confirmed attendance",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "guest_management",
      "action_category": "computation",
      "pre_condition": "Wedding event must exist",
      "post_condition": "Total confirmed guest count is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          }
        },
        "required": [
          "wedding_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "confirmed_count": {
            "description": "Number of guests who confirmed attendance",
            "type": "integer",
            "examples": [
              120
            ]
          },
          "declined_count": {
            "description": "Number of guests who declined",
            "type": "integer",
            "examples": [
              15
            ]
          },
          "pending_count": {
            "description": "Number of guests with pending RSVP",
            "type": "integer",
            "examples": [
              15
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "guest"
      ]
    },
    {
      "name": "create_vendor_contract",
      "description": "Create a contract record for a wedding vendor with service details and pricing",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "vendor_management",
      "action_category": "data_creation",
      "pre_condition": "Wedding event must exist",
      "post_condition": "Vendor contract is created",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "vendor_name": {
            "description": "Name of the vendor company",
            "type": "string",
            "examples": [
              "Elegant Flowers Co"
            ]
          },
          "vendor_type": {
            "description": "Type of service provided by the vendor",
            "type": "string",
            "enum": [
              "florist",
              "photographer",
              "caterer",
              "dj",
              "videographer",
              "decorator",
              "baker",
              "planner",
              "transportation",
              "entertainment"
            ],
            "examples": [
              "florist"
            ]
          },
          "contract_amount": {
            "description": "Total contract amount in dollars",
            "type": "number",
            "examples": [
              2500.0
            ]
          },
          "deposit_amount": {
            "description": "Deposit amount required in dollars",
            "type": "number",
            "examples": [
              500.0
            ]
          },
          "service_date": {
            "description": "Date when the service will be provided in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2025-06-15 10:00:00"
            ]
          },
          "contact_person": {
            "description": "Name of the contact person at the vendor",
            "type": "string",
            "examples": [
              "Jane Anderson"
            ]
          },
          "contact_phone": {
            "description": "Phone number of the vendor contact",
            "type": "string",
            "examples": [
              "+1-555-0456"
            ]
          }
        },
        "required": [
          "wedding_id",
          "vendor_name",
          "vendor_type",
          "contract_amount"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "contract_id": {
            "description": "Unique identifier for the vendor contract",
            "type": "string",
            "examples": [
              "VENDOR001"
            ]
          },
          "creation_timestamp": {
            "description": "Timestamp when the contract was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-12-01 14:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "vendor_contract"
      ]
    },
    {
      "name": "create_task",
      "description": "Create a wedding planning task with deadline and assignment",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "task_management",
      "action_category": "data_creation",
      "pre_condition": "Wedding event must exist",
      "post_condition": "Task is created",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "task_title": {
            "description": "Title of the task",
            "type": "string",
            "examples": [
              "Book photographer"
            ]
          },
          "task_description": {
            "description": "Detailed description of the task",
            "type": "string",
            "examples": [
              "Research and book a professional wedding photographer"
            ]
          },
          "due_date": {
            "description": "Deadline for the task in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2025-03-01 23:59:59"
            ]
          },
          "priority": {
            "description": "Priority level of the task",
            "type": "string",
            "enum": [
              "low",
              "medium",
              "high",
              "urgent"
            ],
            "examples": [
              "high"
            ]
          },
          "assigned_to": {
            "description": "Name of the person assigned to the task",
            "type": "string",
            "examples": [
              "Emily Johnson"
            ]
          },
          "category": {
            "description": "Category of the task",
            "type": "string",
            "enum": [
              "venue",
              "vendors",
              "guests",
              "attire",
              "decorations",
              "invitations",
              "logistics",
              "legal",
              "other"
            ],
            "examples": [
              "vendors"
            ]
          }
        },
        "required": [
          "wedding_id",
          "task_title",
          "due_date",
          "priority"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "task_id": {
            "description": "Unique identifier for the created task",
            "type": "string",
            "examples": [
              "TASK001"
            ]
          },
          "creation_timestamp": {
            "description": "Timestamp when the task was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-12-01 16:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "task"
      ]
    },
    {
      "name": "calculate_budget_variance",
      "description": "Calculate the variance between allocated budget and actual spending for each category",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "budget_management",
      "action_category": "data_analysis",
      "pre_condition": "Wedding event must exist with budget categories",
      "post_condition": "Budget variance analysis is returned",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          }
        },
        "required": [
          "wedding_id"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "category_variances": {
            "description": "List of categories with variance details",
            "type": "array",
            "items": {
              "type": "object"
            },
            "examples": [
              [
                {
                  "category_name": "catering",
                  "allocated": 8000.0,
                  "spent": 8500.0,
                  "variance": -500.0,
                  "variance_percentage": -6.25
                }
              ]
            ]
          },
          "overall_variance": {
            "description": "Overall budget variance in dollars",
            "type": "number",
            "examples": [
              -2000.0
            ]
          }
        }
      },
      "raises": "KeyError",
      "tool_type": "READ",
      "related_databases": [
        "budget_category",
        "expense"
      ]
    },
    {
      "name": "mark_gift_as_purchased",
      "description": "Mark a gift item as purchased by a guest",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "gift_registry_management",
      "action_category": "data_modification",
      "pre_condition": "Gift item must exist in registry",
      "post_condition": "Gift item purchase status is updated",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "item_id": {
            "description": "Unique identifier of the gift item",
            "type": "string",
            "examples": [
              "ITEM001"
            ]
          },
          "purchased_by": {
            "description": "Name of the guest who purchased the item",
            "type": "string",
            "examples": [
              "Sarah Williams"
            ]
          },
          "quantity_purchased": {
            "description": "Number of items purchased",
            "type": "integer",
            "examples": [
              1
            ]
          },
          "purchase_date": {
            "description": "Date when the item was purchased in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-12-20 15:00:00"
            ]
          }
        },
        "required": [
          "wedding_id",
          "item_id",
          "purchased_by",
          "quantity_purchased"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether the update was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "remaining_quantity": {
            "description": "Remaining quantity needed",
            "type": "integer",
            "examples": [
              0
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "gift_item"
      ]
    },
    {
      "name": "create_photo_album",
      "description": "Create a photo album for wedding photos with metadata",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "photo_management",
      "action_category": "data_creation",
      "pre_condition": "Wedding event must exist",
      "post_condition": "Photo album is created",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "album_name": {
            "description": "Name of the photo album",
            "type": "string",
            "examples": [
              "Ceremony Photos"
            ]
          },
          "album_description": {
            "description": "Description of the album",
            "type": "string",
            "examples": [
              "Photos from the wedding ceremony"
            ]
          },
          "photographer_name": {
            "description": "Name of the photographer",
            "type": "string",
            "examples": [
              "John Photography Studio"
            ]
          },
          "album_date": {
            "description": "Date when photos were taken in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2025-06-15 14:00:00"
            ]
          }
        },
        "required": [
          "wedding_id",
          "album_name"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "album_id": {
            "description": "Unique identifier for the photo album",
            "type": "string",
            "examples": [
              "ALBUM001"
            ]
          },
          "creation_timestamp": {
            "description": "Timestamp when the album was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2025-06-16 10:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "photo_album"
      ]
    },
    {
      "name": "create_timeline_event",
      "description": "Create a timeline event for the wedding day schedule",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "timeline_management",
      "action_category": "data_creation",
      "pre_condition": "Wedding event must exist",
      "post_condition": "Timeline event is created",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "event_name": {
            "description": "Name of the timeline event",
            "type": "string",
            "examples": [
              "Ceremony begins"
            ]
          },
          "start_time": {
            "description": "Start time of the event in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2025-06-15 14:00:00"
            ]
          },
          "end_time": {
            "description": "End time of the event in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2025-06-15 14:30:00"
            ]
          },
          "location": {
            "description": "Location where the event takes place",
            "type": "string",
            "examples": [
              "Main Chapel"
            ]
          },
          "description": {
            "description": "Detailed description of the event",
            "type": "string",
            "examples": [
              "Wedding ceremony with processional and vows"
            ]
          },
          "responsible_person": {
            "description": "Person responsible for this event",
            "type": "string",
            "examples": [
              "Wedding Coordinator"
            ]
          }
        },
        "required": [
          "wedding_id",
          "event_name",
          "start_time",
          "end_time"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "timeline_event_id": {
            "description": "Unique identifier for the timeline event",
            "type": "string",
            "examples": [
              "TIMELINE001"
            ]
          },
          "creation_timestamp": {
            "description": "Timestamp when the event was created in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2024-12-01 18:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "timeline_event"
      ]
    },
    {
      "name": "update_wedding_date",
      "description": "Update the date and time of a wedding event",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "event_management",
      "action_category": "data_modification",
      "pre_condition": "Wedding event must exist and new date must be valid",
      "post_condition": "Wedding date is updated",
      "parameters": {
        "type": "object",
        "properties": {
          "wedding_id": {
            "description": "Unique identifier of the wedding event",
            "type": "string",
            "examples": [
              "WED20250615001"
            ]
          },
          "new_wedding_date": {
            "description": "New date and time for the wedding in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2025-07-20 15:00:00"
            ]
          }
        },
        "required": [
          "wedding_id",
          "new_wedding_date"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "success": {
            "description": "Indicates whether the update was successful",
            "type": "boolean",
            "examples": [
              true
            ]
          },
          "updated_date": {
            "description": "The new wedding date in yyyy-mm-dd HH:MM:SS format",
            "type": "string",
            "examples": [
              "2025-07-20 15:00:00"
            ]
          }
        }
      },
      "raises": "ValueError",
      "tool_type": "READ",
      "related_databases": [
        "wedding_event"
      ]
    },
    {
      "name": "calculate_per_guest_cost",
      "description": "Calculate the average cost per guest for the wedding",
      "group": "wedding_planning.Wedding_Management_Suite",
      "object_category": "budget_management",
      "action_category": "computation",
      "pre_condition": "Valid total cost and guest count must be provided",
      "post_condition": "Per guest cost is calculated",
      "parameters": {
        "type": "object",
        "properties": {
          "total_wedding_cost": {
            "description": "Total cost of the wedding in dollars",
            "type": "number",
            "examples": [
              50000.0
            ]
          },
          "confirmed_guest_count": {
            "description": "Number of confirmed guests attending",
            "type": "integer",
            "examples": [
              120
            ]
          }
        },
        "required": [
          "total_wedding_cost",
          "confirmed_guest_count"
        ]
      },
      "returns": {
        "type": "object",
        "properties": {
          "per_guest_cost": {
            "description": "Average cost per guest in dollars",
            "type": "number",
            "examples": [
              416.67
            ]
          },
          "total_cost": {
            "description": "Total wedding cost in dollars",
            "type": "number",
            "examples": [
              50000.0
            ]
          },
          "guest_count": {
            "description": "Number of guests used in calculation",
            "type": "integer",
            "examples": [
              120
            ]
          }
        }
      },
      "raises": "ZeroDivisionError",
      "tool_type": "GENERIC",
      "related_databases": []
    }
  ],
  "schema_classification": {
    "WeddingEvent": {
      "schema_name": "WeddingEvent",
      "instance_key": "wedding_id",
      "fields": [
        {
          "field_name": "wedding_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识符，每次生成都不同"
        },
        {
          "field_name": "bride_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "人名，可能有不同书写方式但语义上等价"
        },
        {
          "field_name": "groom_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "人名，可能有不同书写方式但语义上等价"
        },
        {
          "field_name": "wedding_date",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期和时间，必须精确匹配"
        },
        {
          "field_name": "venue_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "地点名称，自然语言表达可能不同但语义相同"
        },
        {
          "field_name": "wedding_theme",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "婚礼主题，自由文本描述，不同措辞可表达相同含义"
        },
        {
          "field_name": "estimated_guest_count",
          "field_type": "Optional[int]",
          "comparison_type": "strict",
          "reason": "数值，必须精确匹配"
        },
        {
          "field_name": "creation_timestamp",
          "field_type": "datetime",
          "comparison_type": "ignore",
          "reason": "记录创建时间，通常每次生成都不同，不影响实际业务等价性"
        }
      ]
    },
    "Guest": {
      "schema_name": "Guest",
      "instance_key": "guest_id",
      "fields": [
        {
          "field_name": "guest_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识每个宾客，每次工具执行时可能不同"
        },
        {
          "field_name": "wedding_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，指向婚礼事件，必须严格匹配"
        },
        {
          "field_name": "guest_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "姓名，不同写法或格式可能表达同一人，应进行语义比较"
        },
        {
          "field_name": "email",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "电子邮件地址，作为标识必须严格匹配"
        },
        {
          "field_name": "phone_number",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "电话号码，通常作为联系信息，应严格匹配"
        },
        {
          "field_name": "meal_preference",
          "field_type": "Optional",
          "comparison_type": "semantic",
          "reason": "膳食偏好，可能存在不同表达方式但含义相同，应语义比较"
        },
        {
          "field_name": "plus_one_allowed",
          "field_type": "Optional[bool]",
          "comparison_type": "strict",
          "reason": "布尔值，表示是否允许携带陪同，必须严格匹配"
        },
        {
          "field_name": "rsvp_status",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，表示宾客回复状态，必须严格匹配"
        },
        {
          "field_name": "response_date",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "日期时间，表示RSVP收到的时间，必须严格匹配"
        },
        {
          "field_name": "added_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，记录添加宾客的具体时间，必须严格匹配"
        }
      ]
    },
    "VendorContract": {
      "schema_name": "VendorContract",
      "instance_key": "contract_id",
      "fields": [
        {
          "field_name": "contract_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，每次执行都不同"
        },
        {
          "field_name": "wedding_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须严格匹配"
        },
        {
          "field_name": "vendor_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "公司名称，不同措辞可以表达相同实体"
        },
        {
          "field_name": "vendor_type",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，表示供应商服务类型，需精确匹配"
        },
        {
          "field_name": "contract_amount",
          "field_type": "float",
          "comparison_type": "strict",
          "reason": "数值金额，必须精确匹配"
        },
        {
          "field_name": "deposit_amount",
          "field_type": "Optional[float]",
          "comparison_type": "strict",
          "reason": "数值金额，必须精确匹配"
        },
        {
          "field_name": "service_date",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "日期时间，需精确匹配"
        },
        {
          "field_name": "contact_person",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "联系人姓名，不同表达可以是同一人"
        },
        {
          "field_name": "contact_phone",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "电话号码，需精确匹配"
        },
        {
          "field_name": "payment_status",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，表示付款状态，需精确匹配"
        },
        {
          "field_name": "amount_paid",
          "field_type": "float",
          "comparison_type": "strict",
          "reason": "数值金额，必须精确匹配"
        },
        {
          "field_name": "payment_date",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "日期时间，需精确匹配"
        },
        {
          "field_name": "creation_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "创建时间戳，需精确匹配"
        }
      ]
    },
    "BudgetCategory": {
      "schema_name": "BudgetCategory",
      "instance_key": "category_id",
      "fields": [
        {
          "field_name": "category_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识预算类别，由系统随机生成，每次不同"
        },
        {
          "field_name": "wedding_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，引用婚礼事件，必须精确匹配"
        },
        {
          "field_name": "category_name",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "预算类别名称，通常为枚举值或正式命名，需严格匹配"
        },
        {
          "field_name": "allocated_amount",
          "field_type": "float",
          "comparison_type": "strict",
          "reason": "数值金额，必须精确匹配，任何差异都很重要"
        },
        {
          "field_name": "notes",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本说明，不同措辞可以表达相同含义"
        },
        {
          "field_name": "creation_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "创建时间，时间戳必须严格一致"
        }
      ]
    },
    "Expense": {
      "schema_name": "Expense",
      "instance_key": "expense_id",
      "fields": [
        {
          "field_name": "expense_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，工具随机生成，每次执行都不同"
        },
        {
          "field_name": "wedding_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以正确关联婚礼事件"
        },
        {
          "field_name": "category_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以正确关联预算类别"
        },
        {
          "field_name": "expense_description",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "自由文本描述，不同措辞可以表达相同含义"
        },
        {
          "field_name": "amount",
          "field_type": "float",
          "comparison_type": "strict",
          "reason": "数值金额，任何细微差异都很重要"
        },
        {
          "field_name": "expense_date",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，必须精确匹配以反映真实发生时间"
        },
        {
          "field_name": "payment_method",
          "field_type": "Optional",
          "comparison_type": "strict",
          "reason": "枚举值或支付方式，支付方式细微差异可能导致业务不同"
        }
      ]
    },
    "Task": {
      "schema_name": "Task",
      "instance_key": "task_id",
      "fields": [
        {
          "field_name": "task_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识符为随机生成，每次执行都不同"
        },
        {
          "field_name": "wedding_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，引用其他记录，必须精确匹配"
        },
        {
          "field_name": "task_title",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "任务标题为自然语言文本，不同措辞可能表达相同含义"
        },
        {
          "field_name": "task_description",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本描述，不同措辞可以表达相同含义"
        },
        {
          "field_name": "due_date",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "任务截止日期为日期时间字段，必须精确匹配"
        },
        {
          "field_name": "priority",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，任务优先级，必须严格相等"
        },
        {
          "field_name": "assigned_to",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "人名字段，可能不同表达但语义等价"
        },
        {
          "field_name": "category",
          "field_type": "Optional",
          "comparison_type": "strict",
          "reason": "分类字段，通常为枚举或有限集合，必须严格相等"
        },
        {
          "field_name": "status",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，任务状态，必须严格相等"
        },
        {
          "field_name": "completion_date",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "任务完成日期时间，必须精确匹配"
        },
        {
          "field_name": "notes",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "备注为自由文本，不同表达可能语义等价"
        },
        {
          "field_name": "creation_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "记录创建时间，为日期时间字段，必须严格相等"
        }
      ]
    },
    "SeatingTable": {
      "schema_name": "SeatingTable",
      "instance_key": "table_id",
      "fields": [
        {
          "field_name": "table_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，系统自动生成，每次执行可能不同"
        },
        {
          "field_name": "wedding_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须严格对应具体婚礼事件"
        },
        {
          "field_name": "table_number",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "桌号或标识符，通常在实际业务中要求唯一且精确匹配"
        },
        {
          "field_name": "table_capacity",
          "field_type": "int",
          "comparison_type": "strict",
          "reason": "容量数值，必须精确匹配，影响座位安排"
        },
        {
          "field_name": "table_location",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "桌子位置可能有不同自然语言描述，但实际业务认为表达相同区域是等价的"
        },
        {
          "field_name": "table_type",
          "field_type": "Optional",
          "comparison_type": "strict",
          "reason": "类型或形状，通常是枚举值或有限集合，业务上要求精确匹配"
        },
        {
          "field_name": "creation_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "创建时间戳，需精确对应具体数据记录的生成时间"
        }
      ]
    },
    "GuestSeatingAssignment": {
      "schema_name": "GuestSeatingAssignment",
      "instance_key": "assignment_id",
      "fields": [
        {
          "field_name": "assignment_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，用于唯一标识分配记录，每次执行都可能不同"
        },
        {
          "field_name": "wedding_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，指向具体婚礼事件，必须精确匹配"
        },
        {
          "field_name": "guest_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，指向具体宾客，必须精确匹配"
        },
        {
          "field_name": "table_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，指向具体餐桌，必须精确匹配"
        },
        {
          "field_name": "seat_number",
          "field_type": "Optional[int]",
          "comparison_type": "strict",
          "reason": "数值字段，表示具体座位号，必须精确匹配"
        }
      ]
    },
    "TimelineEvent": {
      "schema_name": "TimelineEvent",
      "instance_key": "timeline_event_id",
      "fields": [
        {
          "field_name": "timeline_event_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识每个事件，由工具随机生成，每次执行都不同"
        },
        {
          "field_name": "wedding_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，引用Wedding事件，必须精确匹配"
        },
        {
          "field_name": "event_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "事件名称，可能用不同措辞表达相同含义，属于自由文本"
        },
        {
          "field_name": "start_time",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，必须精确匹配，微小差异也很重要"
        },
        {
          "field_name": "end_time",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，必须精确匹配，微小差异也很重要"
        },
        {
          "field_name": "location",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "地点名称，可能存在不同表达但语义相同的情况"
        },
        {
          "field_name": "description",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "详细描述，自由文本，不同措辞可以表达相同内容"
        },
        {
          "field_name": "responsible_person",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "负责人姓名或称呼，不同表达可能语义相同"
        },
        {
          "field_name": "creation_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "创建时间，属于系统生成时间戳，必须精确匹配"
        }
      ]
    },
    "Invitation": {
      "schema_name": "Invitation",
      "instance_key": "invitation_id",
      "fields": [
        {
          "field_name": "invitation_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，随机生成，每次执行都不同"
        },
        {
          "field_name": "wedding_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保引用的婚礼事件一致"
        },
        {
          "field_name": "guest_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以确保引用的宾客一致"
        },
        {
          "field_name": "delivery_method",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，交付方式差异不可忽略，须严格相等"
        },
        {
          "field_name": "invitation_message",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本描述，不同措辞可以表达相同含义"
        },
        {
          "field_name": "send_date",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "日期时间，发送时间需要精确匹配"
        },
        {
          "field_name": "delivery_status",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "枚举值/状态，任何差异都可能代表不同的业务状态"
        },
        {
          "field_name": "sent_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间戳，精确记录发送时刻，需严格相等"
        }
      ]
    },
    "GiftRegistry": {
      "schema_name": "GiftRegistry",
      "instance_key": "registry_id",
      "fields": [
        {
          "field_name": "registry_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，工具每次生成唯一值，无需比较"
        },
        {
          "field_name": "wedding_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配，确保对应婚礼事件一致"
        },
        {
          "field_name": "registry_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "自由文本名称，不同措辞可能表达同一含义，应语义比较"
        },
        {
          "field_name": "registry_url",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "URL链接，必须完全一致，否则可能指向不同页面"
        },
        {
          "field_name": "store_name",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "店铺名称，可能存在不同写法（如“沃尔玛”与“Walmart”），应语义比较"
        },
        {
          "field_name": "creation_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，记录创建时间，需精确匹配"
        }
      ]
    },
    "GiftItem": {
      "schema_name": "GiftItem",
      "instance_key": "item_id",
      "fields": [
        {
          "field_name": "item_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识gift item，通常由系统自动生成，每次都不同"
        },
        {
          "field_name": "wedding_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，引用wedding event，必须精确匹配"
        },
        {
          "field_name": "registry_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，引用gift registry，必须精确匹配"
        },
        {
          "field_name": "item_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "礼物名称，可能有不同措辞表达相同物品，适合语义比较"
        },
        {
          "field_name": "item_description",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本描述，不同表述可能等价，应语义比较"
        },
        {
          "field_name": "price",
          "field_type": "float",
          "comparison_type": "strict",
          "reason": "数值金额，任何微小差异都重要，需精确匹配"
        },
        {
          "field_name": "quantity_desired",
          "field_type": "int",
          "comparison_type": "strict",
          "reason": "精确的整数数量，必须严格一致"
        },
        {
          "field_name": "quantity_purchased",
          "field_type": "int",
          "comparison_type": "strict",
          "reason": "精确的整数数量，必须严格一致"
        },
        {
          "field_name": "category",
          "field_type": "Optional",
          "comparison_type": "semantic",
          "reason": "物品分类可能有不同名称表达相同类别，适合语义相等判断"
        },
        {
          "field_name": "purchased_by",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "人名，可能有简称/全名等多种表达，应语义比较"
        },
        {
          "field_name": "purchase_date",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "日期时间，需精确匹配"
        },
        {
          "field_name": "creation_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间，需精确匹配"
        }
      ]
    },
    "PhotoAlbum": {
      "schema_name": "PhotoAlbum",
      "instance_key": "album_id",
      "fields": [
        {
          "field_name": "album_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识相册，每次生成可能不同"
        },
        {
          "field_name": "wedding_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，关联婚礼事件，必须精确匹配"
        },
        {
          "field_name": "album_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "相册名称为自由文本，不同措辞可能表达相同含义"
        },
        {
          "field_name": "album_description",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "相册描述为自由文本，不同措辞可以表达相同内容"
        },
        {
          "field_name": "photographer_name",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "摄影师姓名属于人名，不同书写方式可能等价"
        },
        {
          "field_name": "album_date",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "照片拍摄日期，属于关键时间信息，必须精确匹配"
        },
        {
          "field_name": "creation_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "相册创建时间戳，属于时间型字段，必须精确匹配"
        }
      ]
    },
    "Photo": {
      "schema_name": "Photo",
      "instance_key": "photo_id",
      "fields": [
        {
          "field_name": "photo_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，唯一标识每张照片，由系统或工具自动生成，每次执行都可能不同"
        },
        {
          "field_name": "wedding_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，指向婚礼事件，必须精确匹配"
        },
        {
          "field_name": "album_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，指向相册，必须精确匹配"
        },
        {
          "field_name": "photo_url",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "照片文件的路径或URL，必须精确匹配，否则指向不同的照片文件"
        },
        {
          "field_name": "photo_caption",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "照片的说明/标题，为自由文本，不同措辞可以表达同一含义"
        },
        {
          "field_name": "photo_timestamp",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "照片拍摄时间，时间戳，必须精确匹配"
        },
        {
          "field_name": "tags",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "标签或关键词，为自由文本（逗号分隔），不同措辞或顺序可以表达相同含义"
        },
        {
          "field_name": "upload_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "照片上传时间，时间戳，必须精确匹配"
        }
      ]
    },
    "Notification": {
      "schema_name": "Notification",
      "instance_key": "notification_id",
      "fields": [
        {
          "field_name": "notification_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键"
        },
        {
          "field_name": "wedding_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以保证指向同一婚礼事件"
        },
        {
          "field_name": "recipient_type",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，必须精确匹配以确保接收者类型一致"
        },
        {
          "field_name": "recipient_id",
          "field_type": "Optional[str]",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配以保证指向同一接收者"
        },
        {
          "field_name": "reminder_subject",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "自由文本描述，不同措辞可以表达相同主题"
        },
        {
          "field_name": "reminder_message",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "消息内容为自然语言文本，适合语义比较"
        },
        {
          "field_name": "delivery_method",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值（如短信、邮件等），必须精确匹配"
        },
        {
          "field_name": "scheduled_send_time",
          "field_type": "Optional[datetime]",
          "comparison_type": "strict",
          "reason": "日期和时间，必须精确匹配以保证发送时机一致"
        },
        {
          "field_name": "delivery_status",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "状态字段，通常为枚举值，必须精确匹配"
        }
      ]
    },
    "WeddingWebsite": {
      "schema_name": "WeddingWebsite",
      "instance_key": "website_id",
      "fields": [
        {
          "field_name": "website_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，每次生成都不同，比较时应忽略"
        },
        {
          "field_name": "wedding_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，指向唯一婚礼事件，必须严格匹配"
        },
        {
          "field_name": "website_url",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "自定义网站URL，作为唯一标识，必须精确匹配"
        },
        {
          "field_name": "theme_name",
          "field_type": "Optional",
          "comparison_type": "strict",
          "reason": "主题名称为有限集合（枚举），不同主题有实际区别，应严格匹配"
        },
        {
          "field_name": "welcome_message",
          "field_type": "Optional[str]",
          "comparison_type": "semantic",
          "reason": "自由文本欢迎词，不同表达可以等价，应进行语义比较"
        },
        {
          "field_name": "include_rsvp_form",
          "field_type": "Optional[bool]",
          "comparison_type": "strict",
          "reason": "布尔值，功能开关，必须严格一致"
        },
        {
          "field_name": "include_registry_link",
          "field_type": "Optional[bool]",
          "comparison_type": "strict",
          "reason": "布尔值，功能开关，必须严格一致"
        },
        {
          "field_name": "creation_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "创建时间，时间戳属性，必须精确匹配"
        }
      ]
    },
    "MusicPlaylist": {
      "schema_name": "MusicPlaylist",
      "instance_key": "playlist_id",
      "fields": [
        {
          "field_name": "playlist_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，工具随机生成，每次执行都不同"
        },
        {
          "field_name": "wedding_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，引用其他记录，必须严格匹配"
        },
        {
          "field_name": "playlist_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "自由文本名称，不同措辞可以表达相同含义"
        },
        {
          "field_name": "event_segment",
          "field_type": "Literal",
          "comparison_type": "strict",
          "reason": "枚举值，代表婚礼环节，必须精确匹配"
        },
        {
          "field_name": "total_duration_minutes",
          "field_type": "Optional[int]",
          "comparison_type": "strict",
          "reason": "数值型字段，表示时长，必须精确匹配"
        },
        {
          "field_name": "creation_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "时间戳，必须精确匹配"
        }
      ]
    },
    "Song": {
      "schema_name": "Song",
      "instance_key": "song_id",
      "fields": [
        {
          "field_name": "song_id",
          "field_type": "str",
          "comparison_type": "ignore",
          "reason": "主键，随机生成的唯一标识符"
        },
        {
          "field_name": "wedding_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配，确保指向同一个婚礼事件"
        },
        {
          "field_name": "playlist_id",
          "field_type": "str",
          "comparison_type": "strict",
          "reason": "外键ID，必须精确匹配，确保属于同一个播放列表"
        },
        {
          "field_name": "song_title",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "歌曲标题为自然语言文本，不同措辞可能语义等价，如大小写或轻微拼写差异"
        },
        {
          "field_name": "artist_name",
          "field_type": "str",
          "comparison_type": "semantic",
          "reason": "艺术家姓名为自然语言文本，不同写法或顺序可能语义等价"
        },
        {
          "field_name": "duration_seconds",
          "field_type": "Optional[int]",
          "comparison_type": "strict",
          "reason": "数值型字段，歌曲时长，必须精确匹配"
        },
        {
          "field_name": "play_order",
          "field_type": "Optional[int]",
          "comparison_type": "strict",
          "reason": "数值型字段，播放顺序，必须精确匹配以确保顺序一致"
        },
        {
          "field_name": "added_timestamp",
          "field_type": "datetime",
          "comparison_type": "strict",
          "reason": "日期时间字段，必须精确匹配"
        }
      ]
    }
  }
}