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


C# SqlString.Insert方法代碼示例

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


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

示例1: Apply

        public static SqlString Apply(SqlString sql)
        {
            if (text == null)
                return sql;
            var s = "from " + theTable;
            var index = sql.IndexOfCaseInsensitive(s);
            var indexOfSpaceAfterAlias = sql.IndexOf(" ", index + s.Length +1, sql.Length, StringComparison.InvariantCultureIgnoreCase);
            if (indexOfSpaceAfterAlias == -1)
                return sql;

            return sql.Insert(indexOfSpaceAfterAlias, text);
        }
開發者ID:ayende,項目名稱:course-jul-25,代碼行數:12,代碼來源:Optimizations.cs

示例2: PrependComment

		private static SqlString PrependComment(SqlString sql, QueryParameters parameters)
		{
			string comment = parameters.Comment;
			if (string.IsNullOrEmpty(comment))
			{
				return sql;
			}
			else
			{
				return sql.Insert(0, "/* " + comment + " */");
			}
		}
開發者ID:remcoros,項目名稱:nhibernate,代碼行數:12,代碼來源:Loader.cs

示例3: GetLimitString

		public override SqlString GetLimitString(SqlString querySqlString, SqlString offset, SqlString limit)
		{
			/*
			 * "SELECT TOP limit rest-of-sql-statement"
			 */

			SqlStringBuilder topFragment = new SqlStringBuilder();
			topFragment.Add(" top ");
			topFragment.Add(limit);

			return querySqlString.Insert(GetAfterSelectInsertPoint(querySqlString), topFragment.ToSqlString());
		}
開發者ID:kstenson,項目名稱:NHibernate.Search,代碼行數:12,代碼來源:MsSql2000Dialect.cs

示例4: GetLimitString

		public override SqlString GetLimitString(SqlString querySqlString, SqlString offset, SqlString limit)
		{
			var top = new SqlStringBuilder()
				.Add(" top (")
				.Add(limit)
				.Add(")")
				.ToSqlString();

			return querySqlString.Insert(GetAfterSelectInsertPoint(querySqlString), top);
		}
開發者ID:nikson,項目名稱:nhibernate-core,代碼行數:10,代碼來源:MsSqlCeDialect.cs

示例5: GetLimitString

		/// <summary>
		/// Add a <c>LIMIT (TOP)</c> clause to the given SQL <c>SELECT</c>
		/// </summary>
		/// <param name="querySqlString">A Query in the form of a SqlString.</param>
		/// <param name="limit">Maximum number of rows to be returned by the query</param>
		/// <param name="offset">Offset of the first row to process in the result set</param>
		/// <returns>A new SqlString that contains the <c>LIMIT</c> clause.</returns>
		public override SqlString GetLimitString(SqlString querySqlString, int offset, int limit)
		{
			if (offset > 0)
			{
				throw new NotSupportedException("SQL Server does not support an offset");
			}

			/*
			 * "SELECT TOP limit rest-of-sql-statement"
			 */

			return querySqlString.Insert(GetAfterSelectInsertPoint(querySqlString), " top " + limit);
		}
開發者ID:remcoros,項目名稱:nhibernate,代碼行數:20,代碼來源:MsSql2000Dialect.cs

示例6: GetLimitString

		public override SqlString GetLimitString(SqlString querySqlString, int offset, int limit)
		{
			int intSelectInsertPoint = GetAfterSelectInsertPoint(querySqlString);
			string strLimit = string.Format(" top {0} start at {1}", limit, offset + 1);
			return querySqlString.Insert(intSelectInsertPoint, strLimit);
		}
開發者ID:pontillo,項目名稱:PowerNap,代碼行數:6,代碼來源:SybaseASA9Dialect.cs

示例7: GetLimitString

        public override SqlString GetLimitString(SqlString queryString, SqlString offset, SqlString limit)
		{
            // FIXME - This should use the ROWS syntax in Firebird to avoid problems with subqueries metioned here:
            // http://www.firebirdsql.org/refdocs/langrefupd20-select.html#langrefupd20-first-skip

            /*
			 * "SELECT FIRST x [SKIP y] rest-of-sql-statement"
			 */

			int insertIndex = GetAfterSelectInsertPoint(queryString);

            SqlStringBuilder limitFragment = new SqlStringBuilder();

            if (limit != null)
            {
                limitFragment.Add(" first ");
                limitFragment.Add(limit);
            }

            if (offset != null)
            {
                limitFragment.Add(" skip ");
                limitFragment.Add(offset);
			}

            return queryString.Insert(insertIndex, limitFragment.ToSqlString());
		}
開發者ID:Ruhollah,項目名稱:nhibernate-core,代碼行數:27,代碼來源:FirebirdDialect.cs

示例8: GetLimitString

		/// <summary>
		/// Add a <c>FIRST x [SKIP] y</c> clause to the given SQL <c>SELECT</c>
		/// </summary>
		/// <param name="querySqlString">A Query in the form of a SqlString.</param>
		/// <param name="limit">Maximum number of rows to be returned by the query</param>
		/// <param name="offset">Offset of the first row to process in the result set</param>
		/// <returns>A new SqlString that contains the <c>FIRST</c> clause.</returns>
		public override SqlString GetLimitString(SqlString querySqlString, int offset, int limit)
		{
			/*
			 * "SELECT FIRST x [SKIP y] rest-of-sql-statement"
			 */

			int insertIndex = GetAfterSelectInsertPoint(querySqlString);
			if (offset > 0)
			{
				return querySqlString.Insert(insertIndex, " first " + limit.ToString() + " skip " + offset.ToString());
			}
			else
			{
				return querySqlString.Insert(insertIndex, " first " + limit.ToString());
			}
		}
開發者ID:Novthirteen,項目名稱:sconit_timesseiko,代碼行數:23,代碼來源:FirebirdDialect.cs

示例9: Insert

		public void Insert()
		{
			SqlString sql = new SqlString(new object[] { "begin ", Parameter.Placeholder, " end" });

			Assert.AreEqual("beginning ? end", sql.Insert(5, "ning").ToString());
			Assert.AreEqual("begin middle? end", sql.Insert(6, "middle").ToString());
			Assert.AreEqual("begin ?middle end", sql.Insert(7, "middle").ToString());
			Assert.AreEqual("beg|in ? end", sql.Insert(3, "|").ToString());
			Assert.AreEqual("begin ? ending", sql.Insert(11, "ing").ToString());
			Assert.AreEqual("begin ? enXd", sql.Insert(10, "X").ToString());
		}
開發者ID:NikGovorov,項目名稱:nhibernate-core,代碼行數:11,代碼來源:SqlStringFixture.cs

示例10: GetLimitString

		public override SqlString GetLimitString(SqlString querySqlString, SqlString offset, SqlString limit)
		{
			var tokenEnum = new SqlTokenizer(querySqlString).GetEnumerator();
			if (!tokenEnum.TryParseUntilFirstMsSqlSelectColumn()) return null;

			int insertPoint = tokenEnum.Current.SqlIndex;
			return querySqlString.Insert(insertPoint, new SqlString("top ", limit, " "));
		}
開發者ID:marcoCasamento,項目名稱:nhibernate-core,代碼行數:8,代碼來源:MsSql2000Dialect.cs

示例11: GetLimitString

        public override SqlString GetLimitString(SqlString queryString, SqlString offset, SqlString limit)
		{
			/*
             * "SELECT [SKIP x] FIRST y  rest-of-sql-statement"
             */

            // TODO - Check support for cases where only the offset is specified, but the limit is not.  Might need to use int.MaxValue.

			int insertIndex = GetAfterSelectInsertPoint(queryString);

            SqlStringBuilder limitFragment = new SqlStringBuilder();
            if (offset != null)
            {
                limitFragment.Add(" skip ");
                limitFragment.Add(offset);
            }
			if (limit != null)
			{
			    limitFragment.Add(" first ");
			    limitFragment.Add(limit);
			}

			return queryString.Insert(insertIndex, limitFragment.ToSqlString());
		}
開發者ID:NikGovorov,項目名稱:nhibernate-core,代碼行數:24,代碼來源:InformixDialect.cs

示例12: GetLimitString

        public override SqlString GetLimitString(SqlString queryString, SqlString offset, SqlString limit)
        {
            if (offset != null && offset.Length != 0)
                throw new NotSupportedException("Jet Engine 4.0 does not support an offset");

            int insertIndex = GetAfterSelectInsertPoint(queryString);

            var limitFragment = new SqlStringBuilder();

            if (limit != null && limit.Length != 0)
            {
                limitFragment.Add(" TOP ");
                limitFragment.Add(limit);
            }

            return queryString.Insert(insertIndex, limitFragment.ToSqlString());
        }
開發者ID:tgmayfield,項目名稱:nhibernate.jetdriver,代碼行數:17,代碼來源:JetDialect.cs

示例13: GetLimitString

		public override SqlString GetLimitString(SqlString querySqlString, SqlString offset, SqlString limit)
		{
			var top = new SqlString(" top (", limit, ")");
			return querySqlString.Insert(GetAfterSelectInsertPoint(querySqlString), top);
		}
開發者ID:okb,項目名稱:nhibernate-core,代碼行數:5,代碼來源:MsSqlCeDialect.cs

示例14: GetLimitString

        public override SqlString GetLimitString(SqlString queryString, SqlString offset, SqlString limit)
		{
            int intSelectInsertPoint = GetAfterSelectInsertPoint(queryString);

            SqlStringBuilder limitFragment = new SqlStringBuilder();
            limitFragment.Add(" top ");
            if (limit != null)
                limitFragment.Add(limit);
            else
                limitFragment.Add(int.MaxValue.ToString());

            if (offset != null)
            {
                limitFragment.Add(" start at ");
                limitFragment.Add(offset);
            }

            return queryString.Insert(intSelectInsertPoint, limitFragment.ToSqlString());
		}
開發者ID:kstenson,項目名稱:NHibernate.Search,代碼行數:19,代碼來源:SybaseASA9Dialect.cs


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