Class: SqlGenius::Core::Ai::IndexAdvisor
- Inherits:
-
Object
- Object
- SqlGenius::Core::Ai::IndexAdvisor
- Defined in:
- lib/sql_genius/core/ai/index_advisor.rb
Instance Method Summary collapse
- #call(sql, explain_rows) ⇒ Object
-
#initialize(client, config, connection) ⇒ IndexAdvisor
constructor
A new instance of IndexAdvisor.
Constructor Details
#initialize(client, config, connection) ⇒ IndexAdvisor
Returns a new instance of IndexAdvisor.
7 8 9 10 11 |
# File 'lib/sql_genius/core/ai/index_advisor.rb', line 7 def initialize(client, config, connection) @client = client @config = config @connection = connection end |
Instance Method Details
#call(sql, explain_rows) ⇒ Object
13 14 15 16 17 18 19 20 21 22 23 |
# File 'lib/sql_genius/core/ai/index_advisor.rb', line 13 def call(sql, explain_rows) tables = SqlValidator.extract_table_references(sql, @connection) schema = SchemaContextBuilder.new(@connection).call(tables, detail: :with_cardinality) explain_text = explain_rows.map { |row| row.join(" | ") }.join("\n") = [ { role: "system", content: system_prompt }, { role: "user", content: "Query:\n#{sql}\n\nEXPLAIN:\n#{explain_text}\n\nSchema:\n#{schema}" }, ] @client.chat(messages: ) end |