Хранимая процедура C# возвращает все строки в таблице для нулевых значений.C#

Место общения программистов C#
Ответить Пред. темаСлед. тема
Anonymous
 Хранимая процедура C# возвращает все строки в таблице для нулевых значений.

Сообщение Anonymous »

У меня есть метод GetUserPermissions, который возвращает строки разрешений пользователя из базы данных с помощью хранимой процедуры на основе UserId, который передается в качестве параметра. Проблема в том, что он возвращает все строки, если в качестве параметра передано значение null.
Изображение

public static List GetUserPermissions(UserPermissionArgs userPermissionArgs)
{
var permissions = helper.GetModelFromDB("GetUserPermissions", GetNonNullAttributes(userPermissionArgs).ToArray()).ToList();

permissions = permissions.GroupBy(d => d.PermissionId).Select(x => x.First()).ToList();

// Add available permissions that user does not have to list of permissions
var allPermissions = GetPermission(new PermissionArgs() { });

foreach (var permission in allPermissions)
{
if (permissions.All(p => p.PermissionId != permission.Id))
{
permissions.Add(new UserPermission() { PermissionId = permission.Id, State = false });
}
}

Parallel.ForEach(permissions, permission => permission.Permission = GetPermission(new PermissionArgs()
{ PermissionId = permission.PermissionId }).Single());

return permissions.ToList();
}

private static IEnumerable GetNonNullAttributes(object args, bool checkStringsEmpty = true)
{
PropertyInfo[] properties = args.GetType().GetProperties();
List parameters = new List();

foreach (PropertyInfo property in properties)
{
object[] attributes = property.GetCustomAttributes(true);

foreach (var attribute in attributes.Where(attribute => attribute.GetType() == typeof(SpParameter)).Where(attribute => property.GetValue(args) != null))
{
if (checkStringsEmpty && property.GetType() == typeof(string))
{
if (string.IsNullOrEmpty((string)property.GetValue(args)))
{
//If string is empty, don't add it as a parameter
continue;
}
}

SpParameter param = (SpParameter)attribute;
parameters.Add(new SqlParameter(param.Name, property.GetValue(args)));
}
}

return parameters;
}


Подробнее здесь: https://stackoverflow.com/questions/792 ... ull-values
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Хранимая процедура C# возвращает все строки в таблице для нулевых значений.
    Anonymous » » в форуме C#
    0 Ответы
    24 Просмотры
    Последнее сообщение Anonymous
  • Сложная хранимая процедура MySQL возвращает NULL в PHP
    Anonymous » » в форуме Php
    0 Ответы
    35 Просмотры
    Последнее сообщение Anonymous
  • Хранимая процедура сервера MSSQL не возвращает выходные параметры при вызове из С++
    Anonymous » » в форуме C++
    0 Ответы
    29 Просмотры
    Последнее сообщение Anonymous
  • Хранимая процедура не работает в Snowflake
    Anonymous » » в форуме Python
    0 Ответы
    32 Просмотры
    Последнее сообщение Anonymous
  • Не знаю, почему моя хранимая процедура не работает между pyodbc и SQL Server.
    Anonymous » » в форуме Python
    0 Ответы
    30 Просмотры
    Последнее сообщение Anonymous

Вернуться в «C#»