SELECT 
  SQL_CALC_FOUND_ROWS products.product_id, 
  descr1.product as product, 
  companies.company as company_name, 
  products.product_type, 
  products.parent_product_id 
FROM 
  q_products as products 
  LEFT JOIN q_product_options_inventory as inventory ON inventory.product_id = products.product_id 
  LEFT JOIN q_product_descriptions as descr1 ON descr1.product_id = products.product_id 
  AND descr1.lang_code = 'en' 
  LEFT JOIN q_product_prices as prices ON prices.product_id = products.product_id 
  AND prices.lower_limit = 1 
  LEFT JOIN q_companies AS companies ON companies.company_id = products.company_id 
  INNER JOIN q_products_categories as products_categories ON products_categories.product_id = products.product_id 
  INNER JOIN q_categories ON q_categories.category_id = products_categories.category_id 
  AND (
    q_categories.usergroup_ids = '' 
    OR FIND_IN_SET(0, q_categories.usergroup_ids) 
    OR FIND_IN_SET(1, q_categories.usergroup_ids)
  ) 
  AND q_categories.status IN ('A', 'H') 
WHERE 
  1 
  AND q_categories.category_id IN (91, 93, 92, 94, 99) 
  AND companies.status = 'A' 
  AND (
    CASE products.tracking WHEN 'O' THEN inventory.amount > 0 WHEN 'B' THEN products.amount > 0 ELSE 1 END
  ) 
  AND (
    products.usergroup_ids = '' 
    OR FIND_IN_SET(0, products.usergroup_ids) 
    OR FIND_IN_SET(1, products.usergroup_ids)
  ) 
  AND products.status IN ('A') 
  AND prices.usergroup_id IN (0, 0, 1) 
  AND products.parent_product_id = 0 
GROUP BY 
  products.product_id 
ORDER BY 
  products.timestamp desc, 
  products.product_id ASC 
LIMIT 
  360, 30

Query time 0.00711

JSON explain

{
  "query_block": {
    "select_id": 1,
    "cost_info": {
      "query_cost": "121.34"
    },
    "ordering_operation": {
      "using_filesort": true,
      "grouping_operation": {
        "using_temporary_table": true,
        "using_filesort": false,
        "nested_loop": [
          {
            "table": {
              "table_name": "inventory",
              "access_type": "system",
              "possible_keys": [
                "pc"
              ],
              "rows_examined_per_scan": 0,
              "rows_produced_per_join": 1,
              "filtered": "0.00",
              "const_row_not_found": true,
              "cost_info": {
                "read_cost": "0.00",
                "eval_cost": "0.20",
                "prefix_cost": "0.00",
                "data_read_per_join": "976"
              },
              "used_columns": [
                "product_id",
                "amount"
              ]
            }
          },
          {
            "table": {
              "table_name": "q_categories",
              "access_type": "range",
              "possible_keys": [
                "PRIMARY",
                "c_status",
                "p_category_id"
              ],
              "key": "p_category_id",
              "used_key_parts": [
                "category_id"
              ],
              "key_length": "3",
              "rows_examined_per_scan": 5,
              "rows_produced_per_join": 1,
              "filtered": "20.00",
              "using_index": true,
              "cost_info": {
                "read_cost": "6.81",
                "eval_cost": "0.20",
                "prefix_cost": "7.01",
                "data_read_per_join": "2K"
              },
              "used_columns": [
                "category_id",
                "usergroup_ids",
                "status"
              ],
              "attached_condition": "((`portal`.`q_categories`.`category_id` in (91,93,92,94,99)) and ((`portal`.`q_categories`.`usergroup_ids` = '') or find_in_set(0,`portal`.`q_categories`.`usergroup_ids`) or find_in_set(1,`portal`.`q_categories`.`usergroup_ids`)) and (`portal`.`q_categories`.`status` in ('A','H')))"
            }
          },
          {
            "table": {
              "table_name": "products_categories",
              "access_type": "ref",
              "possible_keys": [
                "PRIMARY",
                "pt"
              ],
              "key": "PRIMARY",
              "used_key_parts": [
                "category_id"
              ],
              "key_length": "3",
              "ref": [
                "portal.q_categories.category_id"
              ],
              "rows_examined_per_scan": 156,
              "rows_produced_per_join": 156,
              "filtered": "100.00",
              "using_index": true,
              "cost_info": {
                "read_cost": "4.89",
                "eval_cost": "31.20",
                "prefix_cost": "43.10",
                "data_read_per_join": "2K"
              },
              "used_columns": [
                "product_id",
                "category_id"
              ]
            }
          },
          {
            "table": {
              "table_name": "products",
              "access_type": "eq_ref",
              "possible_keys": [
                "PRIMARY",
                "status",
                "idx_parent_product_id"
              ],
              "key": "PRIMARY",
              "used_key_parts": [
                "product_id"
              ],
              "key_length": "3",
              "ref": [
                "portal.products_categories.product_id"
              ],
              "rows_examined_per_scan": 1,
              "rows_produced_per_join": 138,
              "filtered": "88.70",
              "cost_info": {
                "read_cost": "0.00",
                "eval_cost": "27.67",
                "prefix_cost": "74.30",
                "data_read_per_join": "816K"
              },
              "used_columns": [
                "product_id",
                "product_type",
                "status",
                "company_id",
                "amount",
                "timestamp",
                "usergroup_ids",
                "tracking",
                "parent_product_id"
              ],
              "attached_condition": "((`portal`.`products`.`parent_product_id` = 0) and (case `portal`.`products`.`tracking` when 'O' then <cache>((NULL > 0)) when 'B' then (`portal`.`products`.`amount` > 0) else 1 end) and ((`portal`.`products`.`usergroup_ids` = '') or find_in_set(0,`portal`.`products`.`usergroup_ids`) or find_in_set(1,`portal`.`products`.`usergroup_ids`)) and (`portal`.`products`.`status` = 'A'))"
            }
          },
          {
            "table": {
              "table_name": "companies",
              "access_type": "eq_ref",
              "possible_keys": [
                "PRIMARY"
              ],
              "key": "PRIMARY",
              "used_key_parts": [
                "company_id"
              ],
              "key_length": "4",
              "ref": [
                "portal.products.company_id"
              ],
              "rows_examined_per_scan": 1,
              "rows_produced_per_join": 13,
              "filtered": "10.00",
              "cost_info": {
                "read_cost": "0.00",
                "eval_cost": "2.77",
                "prefix_cost": "101.97",
                "data_read_per_join": "76K"
              },
              "used_columns": [
                "company_id",
                "status",
                "company"
              ],
              "attached_condition": "(`portal`.`companies`.`status` = 'A')"
            }
          },
          {
            "table": {
              "table_name": "descr1",
              "access_type": "eq_ref",
              "possible_keys": [
                "PRIMARY",
                "product_id"
              ],
              "key": "PRIMARY",
              "used_key_parts": [
                "product_id",
                "lang_code"
              ],
              "key_length": "9",
              "ref": [
                "portal.products_categories.product_id",
                "const"
              ],
              "rows_examined_per_scan": 1,
              "rows_produced_per_join": 13,
              "filtered": "100.00",
              "cost_info": {
                "read_cost": "0.00",
                "eval_cost": "2.77",
                "prefix_cost": "104.74",
                "data_read_per_join": "52K"
              },
              "used_columns": [
                "product_id",
                "lang_code",
                "product"
              ]
            }
          },
          {
            "table": {
              "table_name": "prices",
              "access_type": "ref",
              "possible_keys": [
                "usergroup",
                "product_id",
                "lower_limit",
                "usergroup_id"
              ],
              "key": "usergroup",
              "used_key_parts": [
                "product_id"
              ],
              "key_length": "3",
              "ref": [
                "portal.products_categories.product_id"
              ],
              "rows_examined_per_scan": 1,
              "rows_produced_per_join": 13,
              "filtered": "99.95",
              "using_index": true,
              "cost_info": {
                "read_cost": "13.84",
                "eval_cost": "2.77",
                "prefix_cost": "121.34",
                "data_read_per_join": "331"
              },
              "used_columns": [
                "product_id",
                "lower_limit",
                "usergroup_id"
              ],
              "attached_condition": "((`portal`.`prices`.`lower_limit` = 1) and (`portal`.`prices`.`usergroup_id` in (0,0,1)))"
            }
          }
        ]
      }
    }
  }
}

Result

product_id product company_name product_type parent_product_id
41339 Women's Polarized Oval Sunglasses DK4224C3 Jubilee Store LLC P 0
29354 Ski Goggles Outdoor Double Anti-Fog Big Ski Mask Glasses Skiing Snow Snowboard Goggles J D F General Trading LLC P 0
29395 The Classic Round Polarized Sunglasses Yjmh060-3 J D F General Trading LLC P 0
29396 Wolfbike Brand Uv400 Men/ Women Coating Polarized Sunglasses Safety Eyewear Goggle For Riding-Red J D F General Trading LLC P 0
30848 Xiaomi, Mijia Turok Steinhardt Ts Clip Anti-Blue Lens-Yellow Color J D F General Trading LLC P 0
30922 Xiaomi Mijia Anti-Blue Light Goggles Pro -Blue Ink Color J D F General Trading LLC P 0
31133 Xiaomi Mijia Anti-Blue Ray Goggles Pro -Transparent White J D F General Trading LLC P 0
13615 Focal Price X800 Army Glasses 3 Lenses Kit Windproof Uv400 Anti-Fog Exborders FZE P 0
13626 Migvela-AE Man Woman Night Driving Glasses Anti Glaring Vision Driver Safety Exborders FZE P 0
13652 Kaleidoscope Glasses Rainbow Lens Prism Diffraction Exborders FZE P 0
10455 Xiaomi Ts Brand Polarized Stainless Sun Lenses Glasses Mijia Sunglasses Unisex J D F General Trading LLC P 0
10456 Xiaomi Mijia Ts Computer Glasses Uv400 Anti Blue Light Ray Glasses Radiation Protection Red J D F General Trading LLC P 0
1519 Marvel Avengers Sunglass With Wallet-Black SGW-001 Trucare FZC P 0
1520 Disney Cars Sunglass With Wallet SGW-002 Trucare FZC P 0
1521 Disney Frozen 3D Sunglasses, WD19543 Trucare FZC P 0
1524 Disney Cars 3D Sunglasses, WD19542 Trucare FZC P 0
1525 Marvel Spiderman 3D Sunglasses, MV15383 Trucare FZC P 0
1526 Marvel Avengers 3D Sunglasses MV15384, Trucare FZC P 0
1527 Marvel Captian America 3D Sunglasses MV15385, Trucare FZC P 0
1143 Women's Polarized Tort Round Sunglasses - Black JX-0127 A11K Everwin Union General Trading LLC P 0
1142 Big Box Ms. Sunglasses Arrow Polarized True Color Film Thin Face Lens Brown Frame Color Everwin Union General Trading LLC P 0
1141 Big Box Ms. Sunglasses Arrow Polarized True Color Everwin Union General Trading LLC P 0
1140 Women's Box Sunglasses Arrow Polarized True Everwin Union General Trading LLC P 0
1139 Women's Box Sunglasses Arrow Polarized True Color Film Thin Face Lens Color: Black Everwin Union General Trading LLC P 0
1138 Big Box Ms. Sunglasses Polarized Lens In Cherry Blossom Frame Everwin Union General Trading LLC P 0
1137 Big Box Ms. Sunglasses Arrow Sunglasses Polarized Lens Everwin Union General Trading LLC P 0