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


C# SqlString.Append方法代碼示例

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


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

示例1: GetLimitString

		public override SqlString GetLimitString(SqlString querySqlString, int offset, int limit)
		{
			if (querySqlString.IndexOfCaseInsensitive(" ORDER BY ") < 0)
			{
				querySqlString = querySqlString.Append(" ORDER BY GETDATE()");
			}
			return querySqlString.Append(string.Format(" OFFSET {0} ROWS FETCH NEXT {1} ROWS ONLY", offset, limit));
		}
開發者ID:pontillo,項目名稱:PowerNap,代碼行數:8,代碼來源:MsSqlCe40Dialect.cs

示例2: Append

		public void Append()
		{
			SqlString sql = new SqlString(new string[] { "select", " from table" });

			SqlString postAppendSql = sql.Append(" where A=B");

			Assert.IsFalse(sql == postAppendSql, "should be a new object");
			Assert.AreEqual(1, postAppendSql.Count);

			sql = postAppendSql;

			postAppendSql = sql.Append(new SqlString(" and C=D"));

			Assert.AreEqual(1, postAppendSql.Count);

			Assert.AreEqual("select from table where A=B and C=D", postAppendSql.ToString());
		}
開發者ID:NikGovorov,項目名稱:nhibernate-core,代碼行數:17,代碼來源:SqlStringFixture.cs

示例3: Count

		public void Count()
		{
			SqlString sql =
				new SqlString(
					new object[] { "select", " from table where a = ", Parameter.Placeholder, " and b = ", Parameter.Placeholder });
			Assert.AreEqual(4, sql.Count, "Count with no nesting failed.");

			sql = sql.Append(new SqlString(new object[] { " more parts ", " another part " }));
			Assert.AreEqual(5, sql.Count, "Added a SqlString to a SqlString");
		}
開發者ID:NikGovorov,項目名稱:nhibernate-core,代碼行數:10,代碼來源:SqlStringFixture.cs

示例4: ToSqlString

		/// <summary>
		/// Render the SQL fragment
		/// </summary>
		public virtual SqlString ToSqlString(ICriteria criteria, ICriteriaQuery criteriaQuery)
		{
			if(projection!=null)
			{
				SqlString sb=new SqlString();
				SqlString produced = this.projection.ToSqlString(criteria, 0, criteriaQuery, new Dictionary<string, IFilter>());
				SqlString truncated = NHibernate.Util.StringHelper.RemoveAsAliasesFromSql(produced);
				sb = sb.Append(truncated);
				sb = sb.Append(ascending ? " asc" : " desc");
				return sb;
			}

			string[] columns = criteriaQuery.GetColumnAliasesUsingProjection(criteria, propertyName);

			StringBuilder fragment = new StringBuilder();

			ISessionFactoryImplementor factory = criteriaQuery.Factory;
			for (int i = 0; i < columns.Length; i++)
			{
				// TODO H3: bool lower = _ignoreCase && type.SqlTypes( factory )[ i ] == Types.VARCHAR
				bool lower = false;
				if (lower)
				{
					fragment.Append(factory.Dialect.LowercaseFunction)
						.Append("(");
				}
				fragment.Append(columns[i]);

				if (lower)
				{
					fragment.Append(")");
				}

				fragment.Append(ascending ? " asc" : " desc");

				if (i < columns.Length - 1)
				{
					fragment.Append(", ");
				}
			}

			return new SqlString(fragment.ToString());
		}
開發者ID:hazzik,項目名稱:nh-contrib-everything,代碼行數:46,代碼來源:Order.cs

示例5: OuterJoinableAssociation

		public OuterJoinableAssociation(IAssociationType joinableType, String lhsAlias, String[] lhsColumns, String rhsAlias,
		                                JoinType joinType, SqlString withClause, ISessionFactoryImplementor factory,
		                                IDictionary<string, IFilter> enabledFilters)
		{
			this.joinableType = joinableType;
			this.lhsAlias = lhsAlias;
			this.lhsColumns = lhsColumns;
			this.rhsAlias = rhsAlias;
			this.joinType = joinType;
			joinable = joinableType.GetAssociatedJoinable(factory);
			rhsColumns = JoinHelper.GetRHSColumnNames(joinableType, factory);
			on = new SqlString(joinableType.GetOnCondition(rhsAlias, factory, enabledFilters));
			if (StringHelper.IsNotEmpty(withClause))
				on = on.Append(" and ( ").Append(withClause).Append(" )");
			this.enabledFilters = enabledFilters; // needed later for many-to-many/filter application
		}
開發者ID:tkellogg,項目名稱:NHibernate3-withProxyHooks,代碼行數:16,代碼來源:OuterJoinableAssociation.cs

示例6: AppendIdentitySelectToInsert

		public override SqlString AppendIdentitySelectToInsert(SqlString insertString)
		{
			return insertString.Append("\nselect @@identity");
		}
開發者ID:kstenson,項目名稱:NHibernate.Search,代碼行數:4,代碼來源:SybaseASE15Dialect.cs

示例7: AddWhereFragment

		private SqlString AddWhereFragment(SqlString sql)
		{
			if (!hasWhere)
				return sql;
		    return sql.Append(" and ").Append(sqlWhereString);
		}
開發者ID:khaliyo,項目名稱:Spring.net-NHibernate.net-Asp.net-MVC-DWZ-,代碼行數:6,代碼來源:AbstractCollectionPersister.cs

示例8: AddIdentifierOutParameterToInsert

		public override SqlString AddIdentifierOutParameterToInsert(SqlString insertString, string identifierColumnName, string parameterName)
		{
			return insertString.Append(" returning " + identifierColumnName);
		}
開發者ID:rytmis,項目名稱:nhibernate-core,代碼行數:4,代碼來源:PostgreSQLDialect.cs

示例9: AppendOrderByIfNeeded

		private SqlString AppendOrderByIfNeeded(SqlString sqlString)
		{
			SqlString orderByOrEmpty = queryParameters.FilteredSQL.SubstringStartingWithLast("order by");
			return sqlString.Append(orderByOrEmpty);
		}
開發者ID:Novthirteen,項目名稱:sconit_timesseiko,代碼行數:5,代碼來源:SubselectFetch.cs

示例10: AddIdentitySelectToInsert

		public override SqlString AddIdentitySelectToInsert(SqlString insertSql, string identityColumn, string tableName)
		{
			return insertSql.Append("; " + GetIdentitySelectString(identityColumn, tableName));
		}
開發者ID:Novthirteen,項目名稱:sconit_timesseiko,代碼行數:4,代碼來源:MsSql2000Dialect.cs

示例11: ApplyLocksToSql

 /// <summary> 
 /// Modifies the given SQL by applying the appropriate updates for the specified
 /// lock modes and key columns.
 /// </summary>
 /// <param name="sql">the SQL string to modify </param>
 /// <param name="aliasedLockModes">a map of lock modes indexed by aliased table names. </param>
 /// <param name="keyColumnNames">a map of key columns indexed by aliased table names. </param>
 /// <returns> the modified SQL string. </returns>
 /// <remarks>
 /// The behavior here is that of an ANSI SQL <tt>SELECT FOR UPDATE</tt>.  This
 /// method is really intended to allow dialects which do not support
 /// <tt>SELECT FOR UPDATE</tt> to achieve this in their own fashion.
 /// </remarks>
 public virtual SqlString ApplyLocksToSql(SqlString sql, IDictionary aliasedLockModes, IDictionary keyColumnNames)
 {
     return sql.Append(new ForUpdateFragment(this, aliasedLockModes, keyColumnNames).ToSqlStringFragment());
 }
開發者ID:aistrate,項目名稱:TypingPracticeTexts,代碼行數:17,代碼來源:Dialect.cs

示例12: ApplyLocks

		protected override SqlString ApplyLocks( SqlString sql, IDictionary lockModes, Dialect.Dialect dialect )
		{
			if( lockModes == null || lockModes.Count == 0 )
			{
				return sql;
			}
			else 
			{
				IDictionary aliasedLockModes = new Hashtable();
				IEnumerator keys = lockModes.Keys.GetEnumerator();
				object key;
				while ( keys.MoveNext() ) 
				{
					key = keys.Current;
					aliasedLockModes.Add( GetAliasName( (String)  key ), lockModes[key] );
				}
				return sql.Append(new ForUpdateFragment(aliasedLockModes).ToSqlStringFragment(dialect));
			}
		}
開發者ID:rcarrillopadron,項目名稱:nhibernate-1.0.2.0,代碼行數:19,代碼來源:QueryTranslator.cs

示例13: AggregateQueriesInformation

		private void AggregateQueriesInformation()
		{
			sqlString = new SqlString();
			foreach (AbstractQueryImpl query in queries)
			{
				QueryParameters queryParameters = query.GetQueryParameters();
				queryParameters.ValidateParameters();
				query.VerifyParameters();
				IQueryTranslator[] queryTranslators =
					session.GetQueries(query.ExpandParameterLists(queryParameters.NamedParameters), false);
				foreach (QueryTranslator translator in queryTranslators)
				{
					translators.Add(translator);
					parameters.Add(queryParameters);
					queryParameters = GetFilteredQueryParameters(queryParameters, translator);
					SqlCommandInfo commandInfo = translator.GetQueryStringAndTypes(session, queryParameters);
					sqlString = sqlString.Append(commandInfo.Text).Append(dialect.MultipleQueriesSeparator).Append(Environment.NewLine);
					types.AddRange(commandInfo.ParameterTypes);
				}
			}
		}
開發者ID:ray2006,項目名稱:WCell,代碼行數:21,代碼來源:MultiQueryImpl.cs

示例14: Count

		public void Count() 
		{
			SqlString sql = new SqlString( new object[] {"select", " from table where a = ", new Parameter( "p1" ), " and b = " , new Parameter( "p2" ) } );
			Assert.AreEqual( 5, sql.Count, "Count with no nesting failed." );

			sql = sql.Append( new SqlString( new object[] {" more parts ", " another part "} ) );
			Assert.AreEqual( 7, sql.Count, "Added a SqlString to a SqlString" );

			SqlString nestedSql = new SqlString( new object[] { "nested 1", "nested 2" } );

			sql = sql.Append( new SqlString( new object[] { nestedSql, " not nested 1", " not nested 2" } ) );

			Assert.AreEqual( 11, sql.Count, "Added 2 more levels of nesting" );
		}
開發者ID:rcarrillopadron,項目名稱:nhibernate-1.0.2.0,代碼行數:14,代碼來源:SqlStringFixture.cs

示例15: AppendIdentitySelectToInsert

		public override SqlString AppendIdentitySelectToInsert(SqlString insertSql)
		{
			return insertSql.Append("; " + IdentitySelectString);
		}
開發者ID:khaliyo,項目名稱:Spring.net-NHibernate.net-Asp.net-MVC-DWZ-,代碼行數:4,代碼來源:SQLiteDialect.cs


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