Sequence contains no elements ошибка

Hi NG,
  • Remove From My Forums
  • Question

  • Hi NG,

    I’m using the following statemtn to get a record from my database


    Code Snippet

    var productItem = productDtcx.Product.Single(p => p.ProductNumber == «TP00002»);


    In case, when this record is not existing in my database I’m receiving the following exception:

    Code Snippet

    System.InvalidOperationException was unhandled
      Message=»Sequence contains no elements»
      Source=»System.Core»
      StackTrace:
           at System.Linq.Enumerable.Single[TSource](IEnumerable`1 source)
           at System.Data.Linq.SqlClient.SqlProvider.SqlQueryResults`1.PostProcess(Expression query, IEnumerable`1 results)
           at System.Data.Linq.SqlClient.SqlProvider.SqlQueryResults`1.GetEnumerator()
           at System.Linq.Enumerable.Single[TSource](IEnumerable`1 source)
           at System.Data.Linq.Table`1.System.Linq.IQueryable.Execute[S](Expression expression)
           at System.Linq.Queryable.Single[TSource](IQueryable`1 source, Expression`1 predicate)
           at Sample0040.Program.Main(String[] args) in C:Documents and SettingsoaytekinDesktopLINQSamplesSample0040Program.cs:line 19
           at System.AppDomain._nExecuteAssembly(Assembly assembly, String[] args)
           at System.AppDomain.ExecuteAssembly(String assemblyFile, Evidence assemblySecurity, String[] args)
           at Microsoft.VisualStudio.HostingProcess.HostProc.RunUsersAssembly()
           at System.Threading.ThreadHelper.ThreadStart_Context(Object state)
           at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state)
           at System.Threading.ThreadHelper.ThreadStart()
      InnerException:

    I don’t want to catch this exception with a try/catch block. Is there any another method/way to check, if a record is existing or not?

    I want to delete a record. To get and delete the record I’m using the following code

    Code Snippet

    string connString = «Data Source=.;Initial Catalog=AdventureWorks;Integrated Security=True»;

    ProductDataContext productDtcx = new ProductDataContext(connString);

    var productItem = productDtcx.Product.Single(p => p.ProductNumber == «TP00002»);

    productDtcx.Product.Remove(productItem);

    Thx for your help,

    Ozgur Aytekin

Answers

  • Use SingleOrDefault. It returns null if the row isn’t found.

    Anders

Problem

Error message when opening a template in Clarity:

«Clarity.10017 Template build process failed to complete.
Clarity.10023 Error populating grid for maps.
System.InvalidOperationException Sequence contains no elements»

Symptom

When a certain query returns no results (depending on selected page options), the MDX query will be incorrect and will produce the following error in Clarity:

«Clarity.10017 – template build process failed to complete
Clarity.10023 – error populating grid for maps
System.InvalidOperationExceptions – Sequence contains no elements.»

Cause

This is usually caused by one or multiple queries on the database that returns no members. This happens because the OLAP query does not return any rows for a certain combination and it looks like this is the expected behavior for Analysis Services. In other words, the query needs to have a member to search on, otherwise the above error will appear when running the report.

Diagnosing The Problem

Open the template in the Clarity interface

Observe the above error message

Resolving The Problem

Most likely, one of the intersection generated by the template does not exist in the database and one possible cause is that one or multiple members may no longer exist in the cube.

If this is the case, double check if the members added on the template in Studio still exist in the cube.

In order to do that open the template in Studio, under Data, verify the Row and Column members; try to re-select them from the Available Members container. You can locate a dimension member by using the Search box.
After replacing the non-existing members with the existing ones, the template should render as expected.

[{«Product»:{«code»:»SSMVH7″,»label»:»Clarity 7″},»Business Unit»:{«code»:»BU059″,»label»:»IBM Software w/o TPS»},»Component»:»Clarity Server»,»Platform»:[{«code»:»PF033″,»label»:»Windows»}],»Version»:»7.2;7.0″,»Edition»:»»,»Line of Business»:{«code»:»LOB10″,»label»:»Data and AI»}}]

When you start playing with LINQ queries over sequences of elements (e.g. getting min / max value for enumerable source) sooner or later you will come across this one — the InvalidOperationException (“Sequence contains no elements”).

The problem occurs as by default queries like IEnumerable<T>.Min(…) and IEnumerable<T>.Max(…) do not play nicely if you try to execute them on an empty sequence and just throw the exception described above. Unfortunately these methods do not have a corresponding counterpart like Single(…) / SingleOrDefault(…) that is smart enough to query the sequence if it is not empty or alternatively use the default value without raising an exception.

Basically you got two options now:

  • Either perform the check on the enumerable sequence every time you are querying it
  • OR integrate the logic in an extension method.

The second approach is much preferable so let’s add the missing link below:

namespace ExtensionMethods
{
   
using System;
   
using System.Collections.Generic;
   
using System.Linq; public static class IEnumerableExtensions
   
{
       
/// <summary>
        /// Invokes a transform function on each element of a sequence and returns the minimum Double value 
        /// if the sequence is not empty; otherwise returns the specified default value. 
        /// </summary>
        /// <typeparam name=»TSource»>The type of the elements of source.</typeparam>
        /// <param name=»source»>A sequence of values to determine the minimum value of.</param>
        /// <param name=»selector»>A transform function to apply to each element.</param>
        /// <param name=»defaultValue»>The default value.</param>
        /// <returns>The minimum value in the sequence or default value if sequence is empty.</returns>
        public static double MinOrDefault<TSource>(this IEnumerable<TSource> source, Func<TSource, double> selector, double defaultValue)
       
{
           
if (source.Any<TSource>())
               
return source.Min<TSource>(selector);  return defaultValue;
       
} /// <summary>
        /// Invokes a transform function on each element of a sequence and returns the maximum Double value 
        /// if the sequence is not empty; otherwise returns the specified default value. 
        /// </summary>
        /// <typeparam name=»TSource»>The type of the elements of source.</typeparam>
        /// <param name=»source»>A sequence of values to determine the maximum value of.</param>
        /// <param name=»selector»>A transform function to apply to each element.</param>
        /// <param name=»defaultValue»>The default value.</param>
        /// <returns>The maximum value in the sequence or default value if sequence is empty.</returns>
        public static double MaxOrDefault<TSource>(this IEnumerable<TSource> source, Func<TSource, double> selector, double defaultValue)
       
{
           
if (source.Any<TSource>())
               
return source.Max<TSource>(selector);  return defaultValue;
       
}
   
}
}

Now you only need to add the using ExtensionMethods; directive in your project and you are all set:

extensionmethods

Hope this helps.


Comments

All articles

Topics
Latest Stories
in Your Inbox

Subscribe to be the first to get our expert-written articles and tutorials for developers!

All fields are required

Понравилась статья? Поделить с друзьями:
  • Sequelize validation error
  • Sentry мониторинг ошибок
  • Sentry mode has turned off due to a sentry system error
  • Sentry is attempting to send 2 pending error messages
  • Sentinel runtime environment installer error