Officially out now: The TypeDB 3.0 Roadmap >>

Get query

In this guide, you’ll see how to retrieve data from a database using Studio, Console, or one of the drivers.

Understanding Get queries

A Get query is used to retrieve concepts from a TypeDB database. For a detailed explanation of the query see the Get query page.

Sending Get queries

Before you get started, ensure you followed instructions from the Writing data section. The easiest way to send a Get query is to use Studio or Console:

  • Studio

  • Console

Follow the Studio manual to connect to TypeDB and select a project folder. Then use the steps below:

  1. Use a drop-down list in the top toolbar to select a database.

  2. Switch to data session and read transaction types.

  3. Open a new tab and insert or type in an Insert query, for example:

    TypeQL Get query
    match
    $u isa user, has email $e;
    get
    $u, $e;
  4. Run the query by clicking the studio run Run Query button.

  1. Open a data session and read transaction to the selected database (e.g., sample_db):

    transaction sample_db data read
  2. Send the Get query:

    match
    $u isa user, has email $e;
    get
    $u, $e;

    Push Enter twice to send the query.

  3. Close the transaction:

    close

The resulted Log output should look like this:

{
    $e alice@typedb.com isa email;
    $u iid 0x826e80018000000000000000 isa user;
}
{
    $e the-bob@typedb.com isa email;
    $u iid 0x826e80018000000000000001 isa user;
}
{
    $e charlie@typedb.com isa email;
    $u iid 0x826e80018000000000000002 isa user;
}

To send a Get query programmatically, use drivers:

  • Rust

  • Python

  • Node.js

  • Java

  • C#

  • C++

  • C

Follow the connection guide to connect the driver to a TypeDB server.

Open a data session to the selected database, open a read transaction, and use the transaction.query().get() method:
let databases = DatabaseManager::new(driver);
let db = databases.get(DB_NAME)?;
{
    let session = Session::new(db, SessionType::Data)?;
    {
        let tx = session.transaction(TransactionType::Read)?;
        let get_query = "
                        match
                        $u isa user, has email $e;
                        get
                        $e;
                        ";
        let response = tx.query().get(get_query)?;
        for (i, cm) in response.enumerate() {
            let email_concept = cm.unwrap().get("e").unwrap().clone();
            let email = match email_concept {
                Concept::Attribute(Attribute { value: Value::String(value), .. }) => value,
                _ => unreachable!(),
            };
            println!("Email #{}: {}", (i + 1).to_string(), email)
        }
    }
}

Follow the connection guide to connect the driver to a TypeDB server.

Open a data session to the selected database, open a read transaction, and use the transaction.query.get() method:
with driver.session(DB_NAME, SessionType.DATA) as session:
    with session.transaction(TransactionType.READ) as tx:
        get_query = """
                    match
                    $u isa user, has email $e;
                    get
                    $e;
                    """
        response = tx.query.get(get_query)
        for i, concept_map in enumerate(response, start=1):
            email = concept_map.get("e").as_attribute().get_value()
            print(f"Email #{i}: {email}")

Follow the connection guide to connect the driver to a TypeDB server.

Open a data session to the selected database, open a read transaction, and use the transaction.query.get() method:
try {
    session = await driver.session(DB_NAME, SessionType.DATA);
    try {
        tx = await session.transaction(TransactionType.READ);
        const get_query = `
                            match
                            $u isa user, has email $e;
                            get
                            $e;
                            `;
        let response = await tx.query.get(get_query).collect();
        for (let i = 0; i < response.length; i++) {
            console.log("Email #" + (i + 1) + ": " + response[i].get("e").value);
        }
    }
    finally {if (tx.isOpen()) {await tx.close()};}
}
finally {await session?.close();}

Follow the connection guide to connect the driver to a TypeDB server.

Open a data session to the selected database, open a read transaction, and use the transaction.query().get() method:
try (TypeDBSession session = driver.session(DB_NAME, TypeDBSession.Type.DATA)) {
    try (TypeDBTransaction tx = session.transaction(TypeDBTransaction.Type.READ)) {
        String getQuery = """
                            match
                            $u isa user, has email $e;
                            get
                            $e;
                            """;
        int[] ctr = new int[1];
        tx.query().get(getQuery).forEach(result -> System.out.println("Email #" + (++ctr[0]) + ": " + result.get("e").asAttribute().getValue().toString()));
    }
}

Follow the connection guide to connect the driver to a TypeDB server.

Open a data session to the selected database, open a read transaction, and use the transaction.Query.Get() method:
using (ITypeDBSession session = driver.Session(DB_NAME, SessionType.Data)) {
    using (ITypeDBTransaction tx = session.Transaction(TransactionType.Read)) {
        string get_query = @"
                            match
                            $u isa user, has email $e;
                            get
                            $e;";
        List<IConceptMap> response = tx.Query.Get(get_query).ToList();
        foreach (IConceptMap answer in response) {
            Console.WriteLine("Email: " + answer.Get("e").AsAttribute().Value);
        }
    }
}

Follow the connection guide to connect the driver to a TypeDB server.

Open a data session to the selected database, open a read transaction, and use the transaction.query.get() method:
TypeDB::Options options;
TypeDB::Session session = driver.session(DB_NAME, TypeDB::SessionType::DATA, options);
{
    TypeDB::Transaction tx = session.transaction(TypeDB::TransactionType::READ, options);
    std::string getQuery = R"(
                            match
                            $u isa user, has email $e;
                            get
                            $e;
                            )";
    TypeDB::ConceptMapIterable result = tx.query.get(getQuery);
    int16_t i = 0;
    for (TypeDB::ConceptMap& cm : result) {
        i += 1;
        std::cout << "Email #" << std::to_string(i) << ": " << cm.get("e")->asAttribute()->getValue()->asString() << std::endl;
    }
}

Follow the connection guide to connect the driver to a TypeDB server.

Open a data session to the selected database, open a read transaction, and use the query_get() function:
Options* opts = options_new();
session = session_new(databaseManager, DB_NAME, Data, opts);
tx = transaction_new(session, Read, opts);
if ((tx == NULL) || FAILED()) {
    handle_error("Transaction failed to start.");
    goto cleanup;
}
char query[512];
snprintf(query, sizeof(query), "match $u isa user, has email $e; get $e;");
ConceptMapIterator* response = query_get(tx, query, opts);
if (FAILED()) {
    handle_error("Query execution failed.");
    goto cleanup;
}
ConceptMap* CM;
while ((CM = concept_map_iterator_next(response)) != NULL) {
    Concept* emailConcept = concept_map_get(CM, "e");
    printf("%s %s\n", "User:", value_get_string(attribute_get_value(emailConcept)));
}
transaction_close(tx);
session_close(session);

Response interpretation

A Get query returns all concept that were matched by the match clause and filtered by the get clause.

The response is a Stream/Iterator with a ConceptMap object for every solution of a match clause pattern. A concept is returned as a special object with methods relevant to its type.

There are modifiers that can be applied to a Get query that can change its output format:

  • Grouping returns a Stream/Iterator of ConceptMapGroup objects.

  • Aggregation returns Promise of a Value.

  • Grouping with aggregation returns a Stream/Iterator of ValueGroup object.

See the respective drivers API reference for relevant methods to work with these objects:

rustRust
javaJava
cppC++

Learn more

Learn more about Get queries in TypeQL: syntax, behavior, and query examples.

Learn how to write some new data to a database to read.

Check out the Reading data section of TypeDB Academy.