Вы не можете создать GUID просто из строки, строка должна быть Guid соответствует
Guid originalGuid = Guid.NewGuid();
originalGuid.ToString("B") gets converted to {81a130d2-502f-4cf1-a376-63edeb000e9f}
Аналогично
"N" - xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx (32 digits)
"D" - xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx (32 digits separated by hyphens)
"B" - {xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx} (same as "D" with addition of braces)
"P" - (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx) (same as "D" with addition of parentheses)
"X" - {0x00000000,0x0000,0x0000,{0x00,0x00,0x00,0x00,0x00,0x00,0x00.0x00}}
Сам справ не имеет формат. Это просто ценность. Обратите внимание, что вы можете создавать контуры с помощью NewGuid или с помощью конструктора guid. Используя NewGuid, вы не контролируете значение guid. Используя конструктор guid, вы можете контролировать значение. Использование конструктора полезно, если у вас уже есть строковое представление руководства (возможно, вы читаете его из базы данных) или если вы хотите упростить интерпретацию руководства во время разработки. Вы также можете использовать методы Parse, ParseExact, TryParse и TryParseExact.
Таким образом, вы можете создать GUIDs так:
Guid g1 = Guid.NewGuid(); //Get a Guid without any control over the contents
Guid g2 = new Guid(new string('A',32)); //Get a Guid where all digits == 'A'
Guid g3 = Guid.Parse(g1.ToString());
Guid g4 = Guid.ParseExact(g1.ToString("D"),"D");
Guid g5;
bool b1 = Guid.TryParse(g1.ToString(), out g5);
Guid g6;
bool b2 = Guid.TryParseExact(g1.ToString("D"),"D", out g6);
Не конкатенации SQL строки, но параметры использования, чтобы избежать SQL-инъекций и разбора ошибок. Нам нужны значения следующих переменных для ответа на ваш вопрос: 'emp.IdPrestation',' emp.IdPhrase', 'emp.rowguid'. Вы используете их для инициализации «GUID», который должен содержать 32 цифры с четырьмя тире (ошибка не требует пояснений, не так ли?). –
Не могли бы вы привести некоторые значения для emp.IdPrestation, emp.IdPhrase и emp.rowguid? – SWeko