blob: 1e39653fc1e6a3c1820fc91149438280733386d6 [file] [log] [blame]
/*
* Copyright (C) 2019 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef SRC_TRACE_PROCESSOR_SQLITE_DB_SQLITE_TABLE_H_
#define SRC_TRACE_PROCESSOR_SQLITE_DB_SQLITE_TABLE_H_
#include "src/trace_processor/db/table.h"
#include "src/trace_processor/sqlite/sqlite_table.h"
namespace perfetto {
namespace trace_processor {
// Implements the SQLite table interface for db tables.
class DbSqliteTable : public SqliteTable {
public:
class Cursor final : public SqliteTable::Cursor {
public:
explicit Cursor(DbSqliteTable* table);
Cursor(Cursor&&) noexcept = default;
Cursor& operator=(Cursor&&) = default;
// Implementation of SqliteTable::Cursor.
int Filter(const QueryConstraints& qc,
sqlite3_value** argv,
FilterHistory) override;
int Next() override;
int Eof() override;
int Column(sqlite3_context*, int N) override;
private:
enum class Mode {
kSingleRow,
kTable,
};
const Table* SourceTable() const {
// Try and use the sorted cache table (if it exists) to speed up the
// sorting. Otherwise, just use the original table.
return sorted_cache_table_ ? &*sorted_cache_table_ : &*initial_db_table_;
}
Cursor(const Cursor&) = delete;
Cursor& operator=(const Cursor&) = delete;
const Table* initial_db_table_ = nullptr;
// Only valid for Mode::kSingleRow.
base::Optional<uint32_t> single_row_;
// Only valid for Mode::kTable.
base::Optional<Table> db_table_;
base::Optional<Table::Iterator> iterator_;
bool eof_ = true;
// Stores a sorted version of |db_table_| sorted on a repeated equals
// constraint. This allows speeding up repeated subqueries in joins
// significantly.
base::Optional<Table> sorted_cache_table_;
// Stores the count of repeated equality queries to decide whether it is
// wortwhile to sort |db_table_| to create |sorted_cache_table_|.
uint32_t repeated_cache_count_ = 0;
Mode mode_ = Mode::kSingleRow;
std::vector<Constraint> constraints_;
std::vector<Order> orders_;
};
struct QueryCost {
double cost;
uint32_t rows;
};
static void RegisterTable(sqlite3* db,
const Table* table,
const std::string& name);
DbSqliteTable(sqlite3*, const Table* table);
virtual ~DbSqliteTable() override;
// Table implementation.
util::Status Init(int,
const char* const*,
SqliteTable::Schema*) override final;
std::unique_ptr<SqliteTable::Cursor> CreateCursor() override;
int ModifyConstraints(QueryConstraints*) override;
int BestIndex(const QueryConstraints&, BestIndexInfo*) override;
// static for testing.
static QueryCost EstimateCost(const Table& table, const QueryConstraints& qc);
private:
const Table* table_ = nullptr;
};
} // namespace trace_processor
} // namespace perfetto
#endif // SRC_TRACE_PROCESSOR_SQLITE_DB_SQLITE_TABLE_H_