Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Save more on your purchases! discount-offer-chevron-icon
Savings automatically calculated. No voucher code required.
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Free Learning
Arrow right icon
Arrow up icon
GO TO TOP
Elasticsearch 8.x Cookbook

You're reading from   Elasticsearch 8.x Cookbook Over 180 recipes to perform fast, scalable, and reliable searches for your enterprise

Arrow left icon
Product type Paperback
Published in May 2022
Publisher Packt
ISBN-13 9781801079815
Length 750 pages
Edition 5th Edition
Languages
Arrow right icon
Author (1):
Arrow left icon
Alberto Paro Alberto Paro
Author Profile Icon Alberto Paro
Alberto Paro
Arrow right icon
View More author details
Toc

Table of Contents (20) Chapters Close

Preface 1. Chapter 1: Getting Started 2. Chapter 2: Managing Mappings FREE CHAPTER 3. Chapter 3: Basic Operations 4. Chapter 4: Exploring Search Capabilities 5. Chapter 5: Text and Numeric Queries 6. Chapter 6: Relationships and Geo Queries 7. Chapter 7: Aggregations 8. Chapter 8: Scripting in Elasticsearch 9. Chapter 9: Managing Clusters 10. Chapter 10: Backups and Restoring Data 11. Chapter 11: User Interfaces 12. Chapter 12: Using the Ingest Module 13. Chapter 13: Java Integration 14. Chapter 14: Scala Integration 15. Chapter 15: Python Integration 16. Chapter 16: Plugin Development 17. Chapter 17: Big Data Integration 18. Chapter 18: X-Pack 19. Other Books You May Enjoy

Mapping an Alias field

It is very common to have a lot of different types in several indices. Because Elasticsearch makes it possible to search in many indices, you should filter for common fields at the same time.

In the real world, these fields are not always called in the same way in all mappings (generally because they are derived from different entities); it's very common to have a mix of the added_date, timestamp, @timestamp, and date_add fields, all of which are referring to the same date concept.

The alias fields allow you to define an alias name to be resolved, as well as a query time to simplify the call for all the fields with the same meaning.

Getting ready

You will need an up-and-running Elasticsearch installation, as we described in the Downloading and installing Elasticsearch recipe of Chapter 1Getting Started.

To execute the commands in this recipe, you can use any HTTP client, such as curl (https://curl.haxx.se/), Postman (https://www.getpostman.com/), or similar. I suggest using the Kibana console, which provides code completion and better character escaping for Elasticsearch.

How to do it...

If we take the order example that we saw in the previous recipes, we can add an alias for the price value to cost in the item subfield.

This can be achieved by following these steps:

  1. To add this alias, we need to have a mapping that's similar to the following:
    PUT test/_mapping
    { "properties": {
        "id": {"type": "keyword"},
        "date": {"type": "date"},
        "customer_id": {"type": "keyword"},
        "sent": {"type": "boolean"},
        "item": {
          "type": "object",
          "properties": {
            "name": {"type": "keyword"},
            "quantity": {"type": "long"},
            "price": {"type": "double"},
            "vat": {"type": "double"}
    } } } }
  2. Now, we can index a record, as follows:
    PUT test/_doc/1?refresh
    { "id": "1", "date": "2018-11-16T20:07:45Z",
      "customer_id": "100", "sent": true,
      "item": [ { "name": "tshirt", "quantity": 10, "price": 4.3, "vat": 8.5 } ] }
  3. We can search it using the cost alias, like so:
    GET test/_search
    { "query": { "term": { "item.cost": 4.3 } } }

The result will be the saved document.

How it works…

The alias is a convenient way to use the same name for your search field without the need to change the data structure of your fields. An alias field doesn't need to change a document's structure, thus allowing more flexibility for your data models.

The alias is resolved when the search indices in the query are expanded and have no performance penalties due to its usage.

If you try to index a document with a value in an alias field, an exception will be thrown.

The path value of the alias field must contain the full resolution of the target field, which must be concrete and must be known when the alias is defined.

In the case of an alias in a nested object, it must be in the same nested scope as the target.

You have been reading a chapter from
Elasticsearch 8.x Cookbook - Fifth Edition
Published in: May 2022
Publisher: Packt
ISBN-13: 9781801079815
Register for a free Packt account to unlock a world of extra content!
A free Packt account unlocks extra newsletters, articles, discounted offers, and much more. Start advancing your knowledge today.
Unlock this book and the full library FREE for 7 days
Get unlimited access to 7000+ expert-authored eBooks and videos courses covering every tech area you can think of
Renews at $19.99/month. Cancel anytime
Banner background image