⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 standardsafesqlfunction.cs

📁 NHibernate NET开发者所需的
💻 CS
字号:
using System;
using System.Collections.Generic;
using System.Text;
using NHibernate.SqlCommand;
using NHibernate.Type;

namespace NHibernate.Dialect.Function
{
	/// <summary>
	/// Provides a standard implementation that supports the majority of the HQL
	/// functions that are translated to SQL.
	/// </summary>
	/// <remarks>
	/// The Dialect and its sub-classes use this class to provide details required
	/// for processing of the associated function.
	/// </remarks>	
	public class StandardSafeSQLFunction : StandardSQLFunction
	{
		private int allowedArgsCount = 1;
		/// <summary>
		/// Initializes a new instance of the StandardSafeSQLFunction class.
		/// </summary>
		/// <param name="name">SQL function name.</param>
		/// <param name="allowedArgsCount">Exact number of arguments expected.</param>
		public StandardSafeSQLFunction(string name, int allowedArgsCount)
			: base(name)
		{
			this.allowedArgsCount = allowedArgsCount;
		}

		/// <summary>
		/// Initializes a new instance of the StandardSafeSQLFunction class.
		/// </summary>
		/// <param name="name">SQL function name.</param>
		/// <param name="typeValue">Return type for the fuction.</param>
		/// <param name="allowedArgsCount">Exact number of arguments expected.</param>
		public StandardSafeSQLFunction(string name, IType typeValue, int allowedArgsCount)
			: base(name, typeValue)
		{
			this.allowedArgsCount = allowedArgsCount;
		}

		public override SqlString Render(System.Collections.IList args, NHibernate.Engine.ISessionFactoryImplementor factory)
		{
			if (args.Count!= allowedArgsCount)
			{
				throw new QueryException(string.Format("function '{0}' takes {1} arguments.", name, allowedArgsCount));
			}

			return base.Render(args, factory);
		}
	}
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -