nvlfunction.cs
来自「NHibernate NET开发者所需的」· CS 代码 · 共 63 行
CS
63 行
using System;
using System.Collections;
using NHibernate.Engine;
using NHibernate.SqlCommand;
using NHibernate.Type;
namespace NHibernate.Dialect.Function
{
/// <summary>
/// Emulation of coalesce() on Oracle, using multiple nvl() calls
/// </summary>
public class NvlFunction : ISQLFunction
{
public NvlFunction()
{
}
#region ISQLFunction Members
public IType ReturnType(IType columnType, IMapping mapping)
{
return columnType;
}
public bool HasArguments
{
get { return true; }
}
public bool HasParenthesesIfNoArguments
{
get { return true; }
}
public SqlString Render(IList args, ISessionFactoryImplementor factory)
{
// DONE: QueryException if args.Count==0 (not present in H3.2)
if (args.Count == 0)
{
throw new QueryException("nvl(): Not enough parameters.");
}
int lastIndex = args.Count - 1;
object last = args[lastIndex];
args.RemoveAt(lastIndex);
if (lastIndex == 0)
{
return new SqlString(last);
}
object secondLast = args[lastIndex - 1];
SqlStringBuilder nvl = new SqlStringBuilder(5)
.Add("nvl(")
.AddObject(secondLast)
.Add(", ")
.AddObject(last)
.Add(")");
args[lastIndex - 1] = nvl.ToSqlString();
return Render(args, factory);
}
#endregion
}
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?