當前位置: 首頁>>代碼示例>>C#>>正文


C# QueryParameters.LogParameters方法代碼示例

本文整理匯總了C#中NHibernate.Engine.QueryParameters.LogParameters方法的典型用法代碼示例。如果您正苦於以下問題:C# QueryParameters.LogParameters方法的具體用法?C# QueryParameters.LogParameters怎麽用?C# QueryParameters.LogParameters使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在NHibernate.Engine.QueryParameters的用法示例。


在下文中一共展示了QueryParameters.LogParameters方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: Enumerable

		public IEnumerable Enumerable( string query, QueryParameters parameters )
		{
			CheckIsOpen();

			if( log.IsDebugEnabled )
			{
				log.Debug( "GetEnumerable: " + query );
				parameters.LogParameters( factory );
			}

			QueryTranslator[ ] q = GetQueries( query, true );

			if( q.Length == 0 )
			{
				return new ArrayList();
			}

			IEnumerable result = null;
			IEnumerable[ ] results = null;
			bool many = q.Length > 1;
			if( many )
			{
				results = new IEnumerable[q.Length];
			}

			dontFlushFromFind++; //stops flush being called multiple times if this method is recursively called
			//execute the queries and return all results as a single enumerable
			try
			{
				for( int i = 0; i < q.Length; i++ )
				{
					try
					{
						result = q[ i ].GetEnumerable( parameters, this );
					}
					catch( HibernateException )
					{
						// Do not call Convert on HibernateExceptions
						throw;
					}
					catch( Exception sqle )
					{
						throw Convert( sqle, "Could not execute query" );
					}
					if( many )
					{
						results[ i ] = result;
					}
				}

				return many ? new JoinedEnumerable( results ) : result;
			}
			finally
			{
				dontFlushFromFind--;
			}
		}
開發者ID:rcarrillopadron,項目名稱:nhibernate-1.0.2.0,代碼行數:57,代碼來源:SessionImpl.cs

示例2: GetFilterTranslator

		/// <summary>
		/// 1. determine the collection role of the given collection (this may require a flush, if the collection is recorded as unreferenced)
		/// 2. obtain a compiled filter query
		/// 3. autoflush if necessary
		/// </summary>
		/// <param name="collection"></param>
		/// <param name="filter"></param>
		/// <param name="parameters"></param>
		/// <param name="scalar"></param>
		/// <returns></returns>
		private FilterTranslator GetFilterTranslator( object collection, string filter, QueryParameters parameters, bool scalar )
		{
			if( collection == null )
			{
				throw new ArgumentNullException( "collection", "null collection passed to Filter" );
			}

			if( log.IsDebugEnabled )
			{
				log.Debug( "filter: " + filter );
				parameters.LogParameters( factory );
			}

			CollectionEntry entry = GetCollectionEntryOrNull( collection );
			ICollectionPersister roleBeforeFlush = ( entry == null ) ? null : entry.loadedPersister;

			FilterTranslator filterTranslator;
			if( roleBeforeFlush == null )
			{
				// if it was previously unreferenced, we need
				// to flush in order to get its state into the
				// database to query
				Flush();
				entry = GetCollectionEntryOrNull( collection );
				ICollectionPersister roleAfterFlush = ( entry == null ) ? null : entry.loadedPersister;

				if( roleAfterFlush == null )
				{
					throw new QueryException( "the collection was unreferenced" );
				}
				filterTranslator = factory.GetFilter( filter, roleAfterFlush.Role, scalar );
			}
			else
			{
				// otherwise, we only need to flush if there are
				// in-memory changes to the queried tables
				filterTranslator = factory.GetFilter( filter, roleBeforeFlush.Role, scalar );
				if( AutoFlushIfRequired( filterTranslator.QuerySpaces ) )
				{
					// might need to run a different filter entirely after the flush
					// because the collection role may have changed
					entry = GetCollectionEntryOrNull( collection );
					ICollectionPersister roleAfterFlush = ( entry == null ) ? null : entry.loadedPersister;
					if( roleBeforeFlush != roleAfterFlush )
					{
						if( roleAfterFlush == null )
						{
							throw new QueryException( "The collection was dereferenced" );
						}
					}
					filterTranslator = factory.GetFilter( filter, roleAfterFlush.Role, scalar );
				}
			}

			parameters.PositionalParameterValues[ 0 ] = entry.loadedKey;
			parameters.PositionalParameterTypes[ 0 ] = entry.loadedPersister.KeyType;

			return filterTranslator;

		}
開發者ID:rcarrillopadron,項目名稱:nhibernate-1.0.2.0,代碼行數:70,代碼來源:SessionImpl.cs

示例3: Find

		public IList Find( string query, QueryParameters parameters )
		{
			CheckIsOpen();

			if( log.IsDebugEnabled )
			{
				log.Debug( "find: " + query );
				parameters.LogParameters( factory );
			}

			parameters.ValidateParameters();

			QueryTranslator[ ] q = GetQueries( query, false );

			IList results = new ArrayList();

			dontFlushFromFind++; //stops flush being called multiple times if this method is recursively called

			//execute the queries and return all result lists as a single list
			try
			{
				for( int i = 0; i < q.Length; i++ )
				{
					IList currentResults;
					try
					{
						currentResults = q[ i ].List( this, parameters );
					}
					catch( Exception e )
					{
						throw new ADOException( "Could not execute query", e );
					}

					for( int j = 0; j < results.Count; j++ )
					{
						currentResults.Add( results[ j ] );
					}
					results = currentResults;
				}
			}
			finally
			{
				dontFlushFromFind--;
			}
			return results;
		}
開發者ID:rcarrillopadron,項目名稱:nhibernate-1.0.2.0,代碼行數:46,代碼來源:SessionImpl.cs


注:本文中的NHibernate.Engine.QueryParameters.LogParameters方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。