🎉 Try the public beta of the new docs site at algolia.com/doc-beta! 🎉
Guides / Solutions / Ecommerce / B2B catalog management

B2B buyers know what they need to buy and often search using precise product identifiers, such as stock keeping units (SKU). Or, they search for a product that meets strict specifications, which would match several items in your catalog. This guide describes how to set up Algolia to make searching and filtering by numbers easier.

Turning off typo tolerance when searching by SKU

Algolia supports searching by SKU and other numbers by default, if you include them as searchable attributes. By default, typo tolerance is turned on for numbers as well. That’s helpful when you don’t want to limit the search results to exactly matching numbers, for example, when searching for product variants or physical sizes. When searching by SKU however, it’s better to turn off typo tolerance to allow for more precise searching. If you add your SKU attribute to disableTypoToleranceOnAttributes, the search results only include products with exactly matching SKU.

1
2
3
4
5
6
7
$index->setSettings(
  [
    'disableTypoToleranceOnAttributes' => [
      'serial_number',
    ]
  ]
);

Searching in hyphenated attributes

By default, Algolia regards hyphens as separators, so searching for “123-X-456” and “123 X 456” returns the same results. If you also want to allow searching for the number without spaces, for example, “123X456”, it’s important to consider all variations.

Detect searching intent with rules

You can guide buyers effectively by using Rules to detect keywords in a search query.

Let users search by custom aliases for products

B2B buyers often return to buy the same products. Typing or copying SKUs or other lengthy product identifiers every time can be tedious and error-prone. Some ecommerce platforms allow buyers to save a custom alias, or reference, for an item. With Algolia, you can use Rules to support searching by a custom alias to speed up the search.

For example, the buyer can save an alias “my_product” for the product with the ID “123-456-789”. You can create a rule that detects the alias and replaces it with the product ID. When the buyer searches for “my_product”, Algolia applies the rule and returns the product matching the SKU.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
const rule = {
  objectID: 'user_123_alias_1',
  conditions: [
    {
      pattern: 'my_product',
      anchoring: 'contains',
      context: 'user_123'
    }
  ],
  consequence: {
    params: {
      query: {
        type: 'replace',
        delete: 'my_product',
        insert: '123-456-789',
      }
    },
  },
}

Each buyer defines their own aliases. To apply the Rule specific to each buyer, you can use ruleContexts when searching. For example, using an API client:

1
2
3
4
5
6
7
8
9
10
const index = client.initIndex('catalog');

// get the buyer account information
const buyer = getBuyerAccountId();

index.search('query', {
  ruleContext: buyer
}).then(({ hits }) => {
  console.log(hits)
});

Guide users by increasing search precision

For example, if a buyer searches for “article ref21”, they might look for an item that starts with the number “21”. If that’s the case, you can create a Rule to increase the precision of the search, by:

  • Removing the keyword “article”
  • Restricting the searchable attributes to the title and ID

Define a rule using the API clients

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
// Turn JSON into an array
$rule = array(
  'objectID' => 'article-rule',
  'conditions' => array(array(
    'pattern' => 'article',
    'anchoring' => 'startsWith'
  )),
  'consequence' => array(
    'params' => array(
      'query' => array(
        'remove' => 'article'
      ),
      'restrictSearchableAttributes' => array(
        'title',
        'book_id'
      )
    )
  )
);

// Push Rule to index
$index->saveRule($rule);

Define a rule using the Algolia dashboard

  1. Select the Rules section from the left sidebar menu in the Algolia dashboard.
  2. Under the heading Rules, select the index you are adding a Rule to.
  3. Click the New rule button.
  4. Select Create your first rule or New rule. In the dropdown, click on the Manual Editor option.
  5. In the Condition(s) section, keep Query toggled on, select Contains in the dropdown, and enter “article” in the input field.
  6. In the Consequence(s) section:

    • Click the Add consequence button and select Add Query Parameter.
    • In the input field that appears, enter the JSON search parameter you want to add. For example, { "restrictSearchableAttributes": ["title","id"] }.
    • Click the Add consequence button again and select Remove Word.
    • Type or select “article” in the input field.
  7. Save your changes.
Did you find this page helpful?