Я пытаюсь создать метод, который преобразует регулярный оператор sql в объекты С#. Поэтому я решил использовать Ирони для анализа оператора sql, после чего я возвращаю оператор как действие, которое содержит тип оператора и значения это зависит от типа
Вот мой незавершенный код [Потому что я расстроен, потому что не знаю, что делать потом)
private List<Action> ParseStatement(string statement)
{
var parser = new Parser(new SqlGrammar());
var parsed = parser.Parse(statement);
var status = parsed.Status;
while (parsed.Status == ParseTreeStatus.Parsing)
{
Task.Yield();
}
if (status == ParseTreeStatus.Error)
throw new ArgumentException("The statement cannot be parsed.");
ParseTreeNode parsedStmt = parsed.Root.ChildNodes[0];
switch (parsedStmt.Term.Name)
{
case "insertStmt":
var table = parsedStmt.ChildNodes.Find(x => x.Term.Name == "Id").ChildNodes[0].Token.ValueString;
var valuesCount =
parsedStmt.ChildNodes.Find(x => x.Term.Name == "insertData").ChildNodes.Find(
x => x.Term.Name == "exprList").ChildNodes.Count;
var values = parsedStmt.ChildNodes.Find(x => x.Term.Name == "insertData").ChildNodes.Find(
x => x.Term.Name == "exprList").ChildNodes;
foreach (var value in values)
{
string type = value.Token.Terminal.Name;
}
break;
}
return null;
}
private Type ParseType(string type)
{
switch (type)
{
case "number":
return typeof (int);
case "string":
return typeof (string);
}
return null;
}
Итак, вопрос: как я могу использовать Иронию для преобразования строки SQL Statement в объекты С#?
Вот пример того, чего я хочу достичь:
ВСТАВЬТЕ ЧЕЛОВЕК (4, "Нильсен", "Йохан", "Бакен 2", 'Ставангера')
И преобразуйте его в
return new Action<string type, string table, int val1, string val2, string val3, string val4, string val5>;
Динамически зависит от того, что метод прочитал из инструкции.
Надеюсь, я хорошо объяснил свою идею, чтобы вы могли помочь мне, ребята, и если есть что-то непонятное, скажите мне, и я попытаюсь объяснить это.