• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

C# DbFunctionExpression类代码示例

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

本文整理汇总了C#中DbFunctionExpression的典型用法代码示例。如果您正苦于以下问题:C# DbFunctionExpression类的具体用法?C# DbFunctionExpression怎么用?C# DbFunctionExpression使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。



DbFunctionExpression类属于命名空间,在下文中一共展示了DbFunctionExpression类的20个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的C#代码示例。

示例1: Visit

        public override Expression Visit(DbFunctionExpression expression)
        {
            Expression[] arguments = new Expression[expression.Arguments.Count];

            for (int i = 0; i < expression.Arguments.Count; i++)
            {
                arguments[i] = this.Visit(expression.Arguments[i]);
            }

            return this.functionMapper.CreateMethodCall(expression.Function, arguments);
        }
开发者ID:nozerowu,项目名称:ABP,代码行数:11,代码来源:TransformVisitor.Function.cs


示例2: Generate

 public SqlFragment Generate(DbFunctionExpression e, SqlGenerator caller)
 {
     callingGenerator = caller;
     if (bitwiseFunctions.ContainsKey(e.Function.Name))
         return BitwiseFunction(e);
     else if (dateFunctions.ContainsKey(e.Function.Name))
         return GenericFunction(dateFunctions, e);
     else if (stringFunctions.ContainsKey(e.Function.Name))
         return GenericFunction(stringFunctions, e);
     else if (mathFunctions.ContainsKey(e.Function.Name))
         return GenericFunction(mathFunctions, e);
     return null;
 }
开发者ID:luguandao,项目名称:MySql.Data,代码行数:13,代码来源:FunctionFragment.cs


示例3: WriteInstanceFunctionCall

 private static ISqlFragment WriteInstanceFunctionCall(
     SqlGenerator sqlgen, string functionName, DbFunctionExpression functionExpression, bool isPropertyAccess)
 {
     return WriteInstanceFunctionCall(sqlgen, functionName, functionExpression, isPropertyAccess, null);
 }
开发者ID:jimmy00784,项目名称:entityframework,代码行数:5,代码来源:SqlFunctionCallHandler.cs


示例4: HandleSpatialCanonicalFunction

 private static ISqlFragment HandleSpatialCanonicalFunction(
     SqlGenerator sqlgen, DbFunctionExpression functionExpression, PrimitiveTypeKind spatialTypeKind)
 {
     Debug.Assert(
         spatialTypeKind == PrimitiveTypeKind.Geography || spatialTypeKind == PrimitiveTypeKind.Geometry,
         "Spatial function does not refer to a valid spatial primitive type kind?");
     if (spatialTypeKind == PrimitiveTypeKind.Geography)
     {
         return HandleSpatialCanonicalFunction(
             sqlgen, functionExpression, _geographyFunctionNameToStaticMethodHandlerDictionary,
             _geographyFunctionNameToInstancePropertyNameDictionary, _geographyRenamedInstanceMethodFunctionDictionary);
     }
     else
     {
         return HandleSpatialCanonicalFunction(
             sqlgen, functionExpression, _geometryFunctionNameToStaticMethodHandlerDictionary,
             _geometryFunctionNameToInstancePropertyNameDictionary, _geometryRenamedInstanceMethodFunctionDictionary);
     }
 }
开发者ID:jimmy00784,项目名称:entityframework,代码行数:19,代码来源:SqlFunctionCallHandler.cs


示例5: HandleSpecialCanonicalFunction

 /// <summary>
 /// Handler for special canonical functions
 /// </summary>
 /// <param name="e"></param>
 /// <returns></returns>
 private static ISqlFragment HandleSpecialCanonicalFunction(SqlGenerator sqlgen, DbFunctionExpression e)
 {
     return HandleSpecialFunction(_canonicalFunctionHandlers, sqlgen, e);
 }
开发者ID:jimmy00784,项目名称:entityframework,代码行数:9,代码来源:SqlFunctionCallHandler.cs


示例6: HandleFunctionArgumentsDefault

        /// <summary>
        /// Default handling on function arguments.
        /// Appends the list of arguments to the given result
        /// If the function is niladic it does not append anything, 
        /// otherwise it appends (arg1, arg2, .., argn)
        /// </summary>
        /// <param name="e"></param>
        /// <param name="result"></param>
        private static void HandleFunctionArgumentsDefault(SqlGenerator sqlgen, DbFunctionExpression e, SqlBuilder result)
        {
            var isNiladicFunction = e.Function.NiladicFunctionAttribute;
            Debug.Assert(
                !(isNiladicFunction && (0 < e.Arguments.Count)),
                "function attributed as NiladicFunction='true' in the provider manifest cannot have arguments");
            if (isNiladicFunction && e.Arguments.Count > 0)
            {
                throw new MetadataException(Strings.SqlGen_NiladicFunctionsCannotHaveParameters);
            }

            if (!isNiladicFunction)
            {
                WriteFunctionArguments(sqlgen, e.Arguments, result);
            }
        }
开发者ID:jimmy00784,项目名称:entityframework,代码行数:24,代码来源:SqlFunctionCallHandler.cs


示例7: HandleFunctionDefaultGivenName

 /// <summary>
 /// Default handling for functions with a given name.
 /// Translates them to FunctionName(arg1, arg2, ..., argn)
 /// </summary>
 /// <param name="e"></param>
 /// <param name="functionName"></param>
 /// <returns></returns>
 private static ISqlFragment HandleFunctionDefaultGivenName(SqlGenerator sqlgen, DbFunctionExpression e, string functionName)
 {
     // NOTE: The order of checks is important in case of CHARINDEX.
     if (CastReturnTypeToInt64(e))
     {
         return HandleFunctionDefaultCastReturnValue(sqlgen, e, functionName, "bigint");
     }
     else if (CastReturnTypeToInt32(sqlgen, e))
     {
         return HandleFunctionDefaultCastReturnValue(sqlgen, e, functionName, "int");
     }
     else if (CastReturnTypeToInt16(e))
     {
         return HandleFunctionDefaultCastReturnValue(sqlgen, e, functionName, "smallint");
     }
     else if (CastReturnTypeToSingle(e))
     {
         return HandleFunctionDefaultCastReturnValue(sqlgen, e, functionName, "real");
     }
     else
     {
         return HandleFunctionDefaultCastReturnValue(sqlgen, e, functionName, null);
     }
 }
开发者ID:jimmy00784,项目名称:entityframework,代码行数:31,代码来源:SqlFunctionCallHandler.cs


示例8: IsSpatialCanonicalFunction

        /// <summary>
        /// Determines whether the given function is a canonical function the translates
        /// to a spatial (geography/geometry) property access or method call.
        /// </summary>
        /// <param name="e"></param>
        /// <returns></returns>
        private static bool IsSpatialCanonicalFunction(DbFunctionExpression e, out PrimitiveTypeKind spatialTypeKind)
        {
            if (e.Function.IsCanonicalFunction())
            {
                if (e.ResultType.IsSpatialType(out spatialTypeKind))
                {
                    return true;
                }

                foreach (var functionParameter in e.Function.Parameters)
                {
                    if (functionParameter.TypeUsage.IsSpatialType(out spatialTypeKind))
                    {
                        return true;
                    }
                }
            }

            spatialTypeKind = default(PrimitiveTypeKind);
            return false;
        }
开发者ID:jimmy00784,项目名称:entityframework,代码行数:27,代码来源:SqlFunctionCallHandler.cs


示例9: CastReturnTypeToInt32

        /// <summary>
        /// determines if the function requires the return type be enforeced by use of a cast expression
        /// </summary>
        /// <param name="e"></param>
        /// <returns></returns>
        internal static bool CastReturnTypeToInt32(SqlGenerator sqlgen, DbFunctionExpression e)
        {
            if (!_functionRequiresReturnTypeCastToInt32.Contains(e.Function.FullName))
            {
                return false;
            }

            return e.Arguments.Select(t => sqlgen.StoreItemCollection.StoreProviderManifest.GetStoreType(t.ResultType))
                .Any(storeType => _maxTypeNames.Contains(storeType.EdmType.Name));
        }
开发者ID:jimmy00784,项目名称:entityframework,代码行数:15,代码来源:SqlFunctionCallHandler.cs


示例10: WrapPredicate

 /// <summary>
 /// Turns a predicate into a statement returning a bit
 /// PREDICATE => CASE WHEN (PREDICATE) THEN CAST(1 AS BIT) WHEN (NOT (PREDICATE)) CAST (O AS BIT) END
 /// The predicate is produced by the given predicateTranslator.
 /// </summary>
 /// <param name="predicateTranslator"></param>
 /// <param name="e"></param>
 /// <returns></returns>
 private static ISqlFragment WrapPredicate(
     Func<SqlGenerator, IList<DbExpression>, SqlBuilder, SqlBuilder> predicateTranslator, SqlGenerator sqlgen, DbFunctionExpression e)
 {
     var result = new SqlBuilder();
     result.Append("CASE WHEN (");
     predicateTranslator(sqlgen, e.Arguments, result);
     result.Append(") THEN cast(1 as bit) WHEN ( NOT (");
     predicateTranslator(sqlgen, e.Arguments, result);
     result.Append(")) THEN cast(0 as bit) END");
     return result;
 }
开发者ID:jimmy00784,项目名称:entityframework,代码行数:19,代码来源:SqlFunctionCallHandler.cs


示例11: HandleCanonicalFunctionEndsWith

 /// <summary>
 /// Handler for EndsWith. Wraps the normal translation with a case statement
 /// </summary>
 /// <param name="sqlgen"></param>
 /// <param name="e"></param>
 /// <returns></returns>
 private static ISqlFragment HandleCanonicalFunctionEndsWith(SqlGenerator sqlgen, DbFunctionExpression e)
 {
     return WrapPredicate(HandleCanonicalFunctionEndsWith, sqlgen, e);
 }
开发者ID:jimmy00784,项目名称:entityframework,代码行数:10,代码来源:SqlFunctionCallHandler.cs


示例12: HandleCanonicalFunctionToUpper

 /// <summary>
 ///  Function rename ToUpper -> UPPER
 /// </summary>
 /// <param name="sqlgen"></param>
 /// <param name="e"></param>
 /// <returns></returns>
 private static ISqlFragment HandleCanonicalFunctionToUpper(SqlGenerator sqlgen, DbFunctionExpression e)
 {
     return HandleFunctionDefaultGivenName(sqlgen, e, "UPPER");
 }
开发者ID:jimmy00784,项目名称:entityframework,代码行数:10,代码来源:SqlFunctionCallHandler.cs


示例13: HandleCanonicalFunctionTrim

        /// <summary>
        /// TRIM(string) -> LTRIM(RTRIM(string))
        /// </summary>
        /// <param name="sqlgen"></param>
        /// <param name="e"></param>
        /// <returns></returns>
        private static ISqlFragment HandleCanonicalFunctionTrim(SqlGenerator sqlgen, DbFunctionExpression e)
        {
            var result = new SqlBuilder();

            result.Append("LTRIM(RTRIM(");

            Debug.Assert(e.Arguments.Count == 1, "Trim should have one argument");
            result.Append(e.Arguments[0].Accept(sqlgen));

            result.Append("))");

            return result;
        }
开发者ID:jimmy00784,项目名称:entityframework,代码行数:19,代码来源:SqlFunctionCallHandler.cs


示例14: HandleCanonicalFunctionAbs

 /// <summary>
 /// Handle the canonical function Abs(). 
 /// </summary>
 /// <param name="sqlgen"></param>
 /// <param name="e"></param>
 /// <returns></returns>
 private static ISqlFragment HandleCanonicalFunctionAbs(SqlGenerator sqlgen, DbFunctionExpression e)
 {
     // Convert the call to Abs(Byte) to a no-op, since Byte is an unsigned type. 
     if (e.Arguments[0].ResultType.IsPrimitiveType(PrimitiveTypeKind.Byte))
     {
         var result = new SqlBuilder();
         result.Append(e.Arguments[0].Accept(sqlgen));
         return result;
     }
     else
     {
         return HandleFunctionDefault(sqlgen, e);
     }
 }
开发者ID:jimmy00784,项目名称:entityframework,代码行数:20,代码来源:SqlFunctionCallHandler.cs


示例15: HandleCanonicalFunctionRoundOrTruncate

        /// <summary>
        /// Common handler for the canonical functions ROUND and TRUNCATE
        /// </summary>
        /// <param name="e"></param>
        /// <param name="round"></param>
        /// <returns></returns>
        private static ISqlFragment HandleCanonicalFunctionRoundOrTruncate(SqlGenerator sqlgen, DbFunctionExpression e, bool round)
        {
            var result = new SqlBuilder();

            // Do not add the cast for the Round() overload having two arguments. 
            // Round(Single,Int32) maps to Round(Double,Int32)due to implicit casting. 
            // We don't need to cast in that case, since the server returned type is same 
            // as the expected  type. Cast is only required for the overload - Round(Single)
            var requiresCastToSingle = false;
            if (e.Arguments.Count == 1)
            {
                requiresCastToSingle = CastReturnTypeToSingle(e);
                if (requiresCastToSingle)
                {
                    result.Append(" CAST(");
                }
            }
            result.Append("ROUND(");

            Debug.Assert(e.Arguments.Count <= 2, "Round or truncate should have at most 2 arguments");
            result.Append(e.Arguments[0].Accept(sqlgen));
            result.Append(", ");

            if (e.Arguments.Count > 1)
            {
                result.Append(e.Arguments[1].Accept(sqlgen));
            }
            else
            {
                result.Append("0");
            }

            if (!round)
            {
                result.Append(", 1");
            }

            result.Append(")");

            if (requiresCastToSingle)
            {
                result.Append(" AS real)");
            }
            return result;
        }
开发者ID:jimmy00784,项目名称:entityframework,代码行数:51,代码来源:SqlFunctionCallHandler.cs


示例16: IsSpecialStoreFunction

 /// <summary>
 /// Determines whether the given function is a store function that
 /// requires special handling
 /// </summary>
 /// <param name="e"></param>
 /// <returns></returns>
 private static bool IsSpecialStoreFunction(DbFunctionExpression e)
 {
     return IsStoreFunction(e.Function)
            && _storeFunctionHandlers.ContainsKey(e.Function.Name);
 }
开发者ID:jimmy00784,项目名称:entityframework,代码行数:11,代码来源:SqlFunctionCallHandler.cs


示例17: IsSpecialCanonicalFunction

 /// <summary>
 /// Determines whether the given function is a canonical function that
 /// requires special handling
 /// </summary>
 /// <param name="e"></param>
 /// <returns></returns>
 private static bool IsSpecialCanonicalFunction(DbFunctionExpression e)
 {
     return e.Function.IsCanonicalFunction()
            && _canonicalFunctionHandlers.ContainsKey(e.Function.Name);
 }
开发者ID:jimmy00784,项目名称:entityframework,代码行数:11,代码来源:SqlFunctionCallHandler.cs


示例18: CastReturnTypeToInt16

 /// <summary>
 /// determines if the function requires the return type be enforeced by use of a cast expression
 /// </summary>
 /// <param name="e"></param>
 /// <returns></returns>
 internal static bool CastReturnTypeToInt16(DbFunctionExpression e)
 {
     return CastReturnTypeToGivenType(e, _functionRequiresReturnTypeCastToInt16, PrimitiveTypeKind.Int16);
 }
开发者ID:jimmy00784,项目名称:entityframework,代码行数:9,代码来源:SqlFunctionCallHandler.cs


示例19: HandleFunctionDefault

 /// <summary>
 /// Default handling for functions. 
 /// Translates them to FunctionName(arg1, arg2, ..., argn)
 /// </summary>
 /// <param name="e"></param>
 /// <returns></returns>
 private static ISqlFragment HandleFunctionDefault(SqlGenerator sqlgen, DbFunctionExpression e)
 {
     return HandleFunctionDefaultGivenName(sqlgen, e, null);
 }
开发者ID:jimmy00784,项目名称:entityframework,代码行数:10,代码来源:SqlFunctionCallHandler.cs


示例20: CastReturnTypeToSingle

 /// <summary>
 /// determines if the function requires the return type be enforeced by use of a cast expression
 /// </summary>
 /// <param name="e"></param>
 /// <returns></returns>
 internal static bool CastReturnTypeToSingle(DbFunctionExpression e)
 {
     //Do not add the cast for the Round() overload having 2 arguments. 
     //Round(Single,Int32) maps to Round(Double,Int32)due to implicit casting. 
     //We don't need to cast in that case, since we expect a Double as return type there anyways.
     return CastReturnTypeToGivenType(e, _functionRequiresReturnTypeCastToSingle, PrimitiveTypeKind.Single);
 }
开发者ID:jimmy00784,项目名称:entityframework,代码行数:12,代码来源:SqlFunctionCallHandler.cs



注:本文中的DbFunctionExpression类示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
C# DbGeometry类代码示例发布时间:2022-05-24
下一篇:
C# DbFixer类代码示例发布时间:2022-05-24
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap