Код написан на C#
Я хочу выполнить код, в котором пользователь будет задавать вопрос базе данных на человеческом языке, а модель Олламы должна проверить базу данных и ответить на вопрос из базы данных. .
Пример: Сколько существует таблиц?
Ответ: он должен подсчитать и отобразить результат.
Я не знаю, как это сделать. Рекомендации будут оценены по достоинству.
Ниже приведен код, который я уже сделал.
Код работает как
Вопрос — Показать таблицы ; (Здесь вопрос записан в виде sql-запроса)
Ответ — отображение всех таблиц
using Microsoft.SemanticKernel;
using Microsoft.SemanticKernel.ChatCompletion;
using Microsoft.Extensions.Logging; // Added for logging
using Microsoft.Extensions.Logging.Debug;
using Microsoft.Extensions.DependencyInjection;
using System;
using MySql.Data.MySqlClient;
using System.Net.Http;
using MySqlConnector;
//Configure the Semantic Kernel
var kernelBuilder = Kernel.CreateBuilder();
#pragma warning disable SKEXP0010
var kernel = kernelBuilder
.AddOpenAIChatCompletion(
modelId: "llama2",
apiKey: "",
endpoint: new Uri("")
)
.Build();
// Create the chat service
var aiModel = kernel.GetRequiredService();
// MySQL connection configuration
var connectionString = ""; // Replace with actual values
using var connection = new MySqlConnector.MySqlConnection(connectionString);
try
{
await connection.OpenAsync();
Console.WriteLine("Connection to the database was successful.");
}
catch (Exception ex)
{
Console.WriteLine($"Error connecting to the database: {ex.Message}");
return;
}
//Conversation loop
while (true)
{
Console.Write("Your question: ");
var question = Console.ReadLine();
// Attempt to execute the input as a SQL query
try
{
var command = new MySqlConnector.MySqlCommand(question, connection);
using var reader = await command.ExecuteReaderAsync();
while (await reader.ReadAsync())
{
for (int i = 0; i < reader.FieldCount; i++)
{
Console.Write($"{reader.GetName(i)}: {reader.GetValue(i)}\t");
}
Console.WriteLine();
}
}
catch (Exception ex)
{
Console.WriteLine($"Error executing query: {ex.Message}");
// If an error occurs, assume the input might be a question for the AI model
try
{
await foreach (var message in aiModel.GetStreamingChatMessageContentsAsync(prompt: question, kernel: kernel))
{
Console.Write(message);
}
Console.WriteLine();
}
catch (Exception aiEx)
{
// Log the error details
Console.WriteLine($"Error: {aiEx.Message}");
}
}
}
Подробнее здесь: https://stackoverflow.com/questions/787 ... ase-ollama
Невозможно задать вопрос на естественном языке базе данных MySQL - Оллама ⇐ C#
Место общения программистов C#
1719998261
Anonymous
Код написан на C#
Я хочу выполнить код, в котором пользователь будет задавать вопрос базе данных на человеческом языке, а модель Олламы должна проверить базу данных и ответить на вопрос из базы данных. .
Пример: Сколько существует таблиц?
Ответ: он должен подсчитать и отобразить результат.
Я не знаю, как это сделать. Рекомендации будут оценены по достоинству.
Ниже приведен код, который я уже сделал.
Код работает как
Вопрос — Показать таблицы ; (Здесь вопрос записан в виде sql-запроса)
Ответ — отображение всех таблиц
using Microsoft.SemanticKernel;
using Microsoft.SemanticKernel.ChatCompletion;
using Microsoft.Extensions.Logging; // Added for logging
using Microsoft.Extensions.Logging.Debug;
using Microsoft.Extensions.DependencyInjection;
using System;
using MySql.Data.MySqlClient;
using System.Net.Http;
using MySqlConnector;
//Configure the Semantic Kernel
var kernelBuilder = Kernel.CreateBuilder();
#pragma warning disable SKEXP0010
var kernel = kernelBuilder
.AddOpenAIChatCompletion(
modelId: "llama2",
apiKey: "",
endpoint: new Uri("")
)
.Build();
// Create the chat service
var aiModel = kernel.GetRequiredService();
// MySQL connection configuration
var connectionString = ""; // Replace with actual values
using var connection = new MySqlConnector.MySqlConnection(connectionString);
try
{
await connection.OpenAsync();
Console.WriteLine("Connection to the database was successful.");
}
catch (Exception ex)
{
Console.WriteLine($"Error connecting to the database: {ex.Message}");
return;
}
//Conversation loop
while (true)
{
Console.Write("Your question: ");
var question = Console.ReadLine();
// Attempt to execute the input as a SQL query
try
{
var command = new MySqlConnector.MySqlCommand(question, connection);
using var reader = await command.ExecuteReaderAsync();
while (await reader.ReadAsync())
{
for (int i = 0; i < reader.FieldCount; i++)
{
Console.Write($"{reader.GetName(i)}: {reader.GetValue(i)}\t");
}
Console.WriteLine();
}
}
catch (Exception ex)
{
Console.WriteLine($"Error executing query: {ex.Message}");
// If an error occurs, assume the input might be a question for the AI model
try
{
await foreach (var message in aiModel.GetStreamingChatMessageContentsAsync(prompt: question, kernel: kernel))
{
Console.Write(message);
}
Console.WriteLine();
}
catch (Exception aiEx)
{
// Log the error details
Console.WriteLine($"Error: {aiEx.Message}");
}
}
}
Подробнее здесь: [url]https://stackoverflow.com/questions/78701118/unable-to-ask-the-natural-language-question-to-mysql-database-ollama[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия