пожалуйста(
задайте вопрос думаю вам ответят
Документация даппера умеет https://dapper-tutorial.net/result-multi-mapping
Есть строка.. var sql = $"SELECT CR.UserName, CR.DeviceName AS device, CR.LoginTS AS loginTime, UCBD.Country AS unexpectedCountry, UCBD.LoginTS AS unexpectedLoginTime FROM ConcurrentUniqueSessionsWithMultipleDevices CR" + " LEFT JOIN dbo.UniqueCountriesByDay UCBD on CR.UserName = UCBD.UserName AND UCBD.LoginTS = CR.LoginTS"; Которая возвращает результуты в столбцы userName, device, loginTime, unexpectedCountry, unexpectedLoginTime А структура данных которые я должен вывести, имеет следующую сигнатуру. public string? userName { get; set; } public string? device { get; set; } public DateTime loginTime { get; set; } public CleanCountryLogin? unexpectedLogin { get; set; } Где CleanCountryLogin обьект из строки и DateTime И я вот никак не могу замапить эти последнее два столбца в моем коде var insurance = db.Query<CleanConcurrentLogins>( sql, (_userName, _device, _loginTime, _country, _unexpectedLoginTime) => { return new CleanConcurrentLogins() { device = _device, loginTime = _loginTime, userName = _userName, unexpectedLogin = new CleanCountryLogin() { country = _country, loginTime = _unexpectedLoginTime } }; }, splitOn: "unexpectedCountry, unexpectedLoginTime").ToList(); что-то ругается..
Думал еще сделать вот так.. var result = db.Query<CleanConcurrentLogins>(sql) .Select(row => new CleanConcurrentLogins() { userName = row.userName, device = row.device, loginTime = row.loginTime, unexpectedLogin = new CleanCountryLogin(){country = row.unexpectedLogin.country, loginTime = row.unexpectedLogin.loginTime}}) .ToList(); Но почему-то нуллреференс
а просто unexpectedLoginTime в splitOn: пробовал?
db.Query<CleanConcurrentLogins,CleanCountryLogin,CleanConcurrentLogins>(sql,(cleanConcurrentLogins,cleanCountryLogin)=> { })
а не, там по unexpectedCountry сплит делать надо
Проблема в том, что мне вот это говорит, argument mismatch var insurance = db.Query<CleanConcurrentLogins>( sql, (_userName, _device, _loginTime, _country, _unexpectedLoginTime) => { return new CleanConcurrentLogins() { device = _device, loginTime = _loginTime, userName = _userName, unexpectedLogin = new CleanCountryLogin() { country = _country, loginTime = _unexpectedLoginTime } }; }, splitOn: "unexpectedCountry, unexpectedLoginTime").ToList(); Хотя я вроде бы по примеру делаю со стека
А почему целых три типа и зачем последний ?
1и 2 тип для маппа 3 тип возвращаемое значение
Сорри за оффтоп. Телега сама коду даёт такой шрифт прикольный?
Когда-то на винде нужно было его мне оборачивать в А сейчас вот что-то перешел на мак и оно само все делает. Я даже ничего не нажимаю.. Без понятия как оно там сейчас. Главное как и прежде
Попробовал сделать как вы и сказали.. var sm = db.Query<CleanConcurrentLogins, CleanCountryLogin, CleanConcurrentLogins>(sql, (cleanConcurrentLogins, cleanCountryLogin) => { return new CleanConcurrentLogins() { device = cleanConcurrentLogins.device, loginTime = cleanConcurrentLogins.loginTime, userName = cleanConcurrentLogins.userName, unexpectedLogin = cleanCountryLogin }; }).ToList(); System.ArgumentException: When using the multi-mapping APIs ensure you set the splitOn param if you have keys other than Id (Parameter 'splitOn') Да что же так сложно-то(
возвращаешь датаридер и вжух =)
cleanConcurrentLogins и есть объект CleanConcurrentLogins ,не надо еще один объект создовать)
@AntonioParroni попробуйте еще spliton как тут сказано добавить
Досплитился блин. var sm = db.Query<CleanConcurrentLogins, CleanCountryLogin, CleanConcurrentLogins>( sql:sql, map: (cleanConcurrentLogins, cleanCountryLogin) => { return new CleanConcurrentLogins() { device = cleanConcurrentLogins.device, loginTime = cleanConcurrentLogins.loginTime, userName = cleanConcurrentLogins.userName, unexpectedLogin = cleanCountryLogin };}, splitOn: "unexpectedCountry, unexpectedLoginTime").ToList(); Оно теперь работает.. но возвращает просто какую-то дичь. Страна не мапится, а время 0001-01-01T00:00:00 Прекрасно
Обсуждают сегодня