I\'m creating a website using WooCommerce and I want to restrict the available products to users depending on the postcode that they enter in the search form on my home page
Update 2020
Products are located mainly in the following tables:
wp_posts table with post_type like product (or product_variation),
wp_postmeta table with post_id as relational index (the product ID).
wp_wc_product_meta_lookup table with product_id as relational index (the post ID) | Allow fast queries on specific product data (since WooCommerce 3.7)
wp_wc_order_product_lookuptable with product_id as relational index (the post ID) | Allow fast queries to retrieve products on orders (since WooCommerce 3.7)
Product types, categories, subcategories, tags, attributes and all other custom taxonomies are located in the following tables:
wp_terms
wp_termmeta
wp_term_taxonomy
wp_term_relationships - column object_id as relational index (the product ID)
wp_woocommerce_termmeta
wp_woocommerce_attribute_taxonomies (for product attributes only)
wp_wc_category_lookup (for product categories hierarchy only since WooCommerce 3.7)
Product types are handled by custom taxonomy product_type with the following default terms:
simplegroupedvariableexternalSome other product types for Subscriptions and Bookings plugins:
subscriptionvariable-subscriptionbookingSince Woocommerce 3+ a new custom taxonomy named product_visibility handle:
exclude-from-search and exclude-from-catalogfeaturedoutofstockrated-1 to rated-5Particular feature: Each product attribute is a custom taxonomy…
References: