当前位置: 首页>>代码示例>>C#>>正文


C# ServiceQueryOptions.GetSqlQueryTop方法代码示例

本文整理汇总了C#中SnCore.WebServices.ServiceQueryOptions.GetSqlQueryTop方法的典型用法代码示例。如果您正苦于以下问题:C# ServiceQueryOptions.GetSqlQueryTop方法的具体用法?C# ServiceQueryOptions.GetSqlQueryTop怎么用?C# ServiceQueryOptions.GetSqlQueryTop使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在SnCore.WebServices.ServiceQueryOptions的用法示例。


在下文中一共展示了ServiceQueryOptions.GetSqlQueryTop方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: GetFavoritePlaces

        public List<TransitPlace> GetFavoritePlaces(string ticket, ServiceQueryOptions serviceoptions)
        {
            using (SnCore.Data.Hibernate.Session.OpenConnection())
            {
                ISession session = SnCore.Data.Hibernate.Session.Current;

                ISQLQuery q = session.CreateSQLQuery(
                    "CREATE TABLE #fav (	[Id] [int],	[Score] [int] )\n" +
                    "INSERT INTO #fav ( [Id], [Score] ) " +
                    " SELECT Place_Id, 1 FROM AccountPlaceFavorite " +
                    "CREATE TABLE #pl (	[Id] [int],	[Score] [int] )\n" +
                    "INSERT INTO #pl ( [Id], [Score] )" +
                    " SELECT Id, SUM(Score) AS 'Score' FROM #fav " +
                    " GROUP BY Id\n" +
                    "SELECT " + (serviceoptions != null ? serviceoptions.GetSqlQueryTop() : string.Empty) +
                    " {Place.*} FROM {Place} INNER JOIN #pl" +
                    " ON #pl.Id = Place.Place_Id" +
                    " ORDER BY [Score] DESC\n" +
                    "DROP TABLE #pl\n" +
                    "DROP TABLE #fav ")
                    .AddEntity("Place", typeof(Place));

                //if (serviceoptions != null)
                //{
                //    q.SetMaxResults(serviceoptions.PageSize);
                //    q.SetFirstResult(serviceoptions.FirstResult);
                //}

                IList<Place> list = WebServiceQueryOptions<Place>.Apply(serviceoptions, q.List<Place>());
                List<TransitPlace> result = new List<TransitPlace>(list.Count);

                ManagedSecurityContext sec = new ManagedSecurityContext(session, ticket);
                foreach (Place p in list)
                {
                    result.Add(new ManagedPlace(session, p).GetTransitInstance(sec));
                }

                return result;
            }
        }
开发者ID:dblock,项目名称:sncore,代码行数:40,代码来源:WebPlaceService.cs

示例2: InternalSearchPlaces

        protected IList<Place> InternalSearchPlaces(ISession session, string s, ServiceQueryOptions options)
        {
            // search for a place matching the name exactly
            IList<Place> places = session.CreateCriteria(typeof(Place))
                .Add(Expression.Eq("Name", Renderer.SqlEncode(s)))
                .List<Place>();

            // search for everything else
            if (places.Count == 0)
            {

                int maxsearchresults = ManagedConfiguration.GetValue(session, "SnCore.MaxSearchResults", 128);
                ISQLQuery query = session.CreateSQLQuery(

                        "CREATE TABLE #Results ( Place_Id int, RANK int )\n" +
                        "CREATE TABLE #Unique_Results ( Place_Id int, RANK int )\n" +

                        "INSERT #Results\n" +
                        "SELECT place.Place_Id, ft.[RANK] FROM Place place\n" +
                        "INNER JOIN FREETEXTTABLE (Place, ([Name], [Street], [Zip], [CrossStreet], [Description], [Phone], [Fax], [Email]), '" +
                            Renderer.SqlEncode(s) + "', " +
                            maxsearchresults.ToString() + ") AS ft ON place.Place_Id = ft.[KEY]\n" +

                        "INSERT #Results\n" +
                        "SELECT place.Place_Id, ft.[RANK] FROM Place place, PlaceName placename\n" +
                        "INNER JOIN FREETEXTTABLE (PlaceName, ([Name]), '" + Renderer.SqlEncode(s) + "', " +
                            maxsearchresults.ToString() + ") AS ft ON placename.PlaceName_Id = ft.[KEY] \n" +
                        "WHERE placename.Place_Id = place.Place_Id\n" +

                        "INSERT #Results\n" +
                        "SELECT place.Place_Id, ft.[RANK] FROM Place place, PlacePropertyValue placepropertyvalue\n" +
                        "INNER JOIN FREETEXTTABLE (PlacePropertyValue, ([Value]), '" + Renderer.SqlEncode(s) + "', " +
                            maxsearchresults.ToString() + ") AS ft ON placepropertyvalue.PlacePropertyValue_Id = ft.[KEY] \n" +
                        "WHERE placepropertyvalue.Place_Id = place.Place_Id\n" +

                        "INSERT #Results\n" +
                        "SELECT place.Place_Id, 0 FROM Place place\n" +
                        "INNER JOIN City city ON place.City_Id = city.City_Id " +
                        "WHERE City.Name = '" + Renderer.SqlEncode(s) + "'\n" +

                        "INSERT #Results\n" +
                        "SELECT place.Place_Id, 0 FROM Place place\n" +
                        "INNER JOIN Neighborhood neighborhood ON place.Neighborhood_Id = neighborhood.Neighborhood_Id " +
                        "WHERE Neighborhood.Name = '" + Renderer.SqlEncode(s) + "'\n" +

                        "INSERT #Unique_Results\n" +
                        "SELECT DISTINCT Place_Id, SUM(RANK)\n" +
                        "FROM #Results GROUP BY Place_Id\n" +
                        "ORDER BY SUM(RANK) DESC\n" +

                        "SELECT " + (options != null ? options.GetSqlQueryTop() : string.Empty) +
                        "{Place.*} FROM {Place}, #Unique_Results\n" +
                        "WHERE Place.Place_Id = #Unique_Results.Place_Id\n" +
                        "ORDER BY #Unique_Results.RANK DESC\n" +

                        "DROP TABLE #Results\n" +
                        "DROP TABLE #Unique_Results")
                        .AddEntity("Place", typeof(Place));

                places = query.List<Place>();
            }

            return WebServiceQueryOptions<Place>.Apply(options, places);
        }
开发者ID:dblock,项目名称:sncore,代码行数:64,代码来源:WebPlaceService.cs

示例3: InternalSearchAccounts

        protected IList<Account> InternalSearchAccounts(ISession session, string s, ServiceQueryOptions options)
        {
            // search for an account matching the name exactly
            IList<Account> accounts = session.CreateCriteria(typeof(Account)).Add(
                Expression.Or(
                    Expression.Eq("Name", Renderer.SqlEncode(s)),
                    Expression.Eq("City", Renderer.SqlEncode(s))
                )).List<Account>();

            // search for everything else
            if (accounts.Count == 0)
            {
                int maxsearchresults = ManagedConfiguration.GetValue(session, "SnCore.MaxSearchResults", 128);
                ISQLQuery query = session.CreateSQLQuery(

                        "CREATE TABLE #Results ( Account_Id int, RANK int )\n" +
                        "CREATE TABLE #Unique_Results ( Account_Id int, RANK int )\n" +

                        "INSERT #Results\n" +
                        "SELECT account.Account_Id, ft.[RANK] FROM Account account\n" +
                        "INNER JOIN FREETEXTTABLE (Account, [Name], '" + Renderer.SqlEncode(s) + "', " +
                            maxsearchresults.ToString() + ") AS ft ON account.Account_Id = ft.[KEY]\n" +

                        //"INSERT #Results\n" +
                    //"SELECT account.Account_Id, ft.[RANK] FROM Account account, AccountSurveyAnswer accountsurveyanswer\n" +
                    //"INNER JOIN FREETEXTTABLE (AccountSurveyAnswer, ([Answer]), '" + Renderer.SqlEncode(s) + "', " +
                    //    maxsearchresults.ToString() + ") AS ft ON accountsurveyanswer.AccountSurveyAnswer_Id = ft.[KEY] \n" +
                    //"WHERE accountsurveyanswer.Account_Id = account.Account_Id\n" +

                        "INSERT #Results\n" +
                        "SELECT account.Account_Id, ft.[RANK] FROM Account account, AccountPropertyValue accountpropertyvalue\n" +
                        "INNER JOIN FREETEXTTABLE (AccountPropertyValue, ([Value]), '" + Renderer.SqlEncode(s) + "', " +
                            maxsearchresults.ToString() + ") AS ft ON accountpropertyvalue.AccountPropertyValue_Id = ft.[KEY] \n" +
                        "WHERE accountpropertyvalue.Account_Id = account.Account_Id\n" +

                        "INSERT #Unique_Results\n" +
                        "SELECT DISTINCT Account_Id, SUM(RANK)\n" +
                        "FROM #Results GROUP BY Account_Id\n" +
                        "ORDER BY SUM(RANK) DESC\n" +

                        "SELECT " + (options != null ? options.GetSqlQueryTop() : string.Empty) +
                        "{Account.*} FROM {Account}, #Unique_Results\n" +
                        "WHERE Account.Account_Id = #Unique_Results.Account_Id\n" +
                        "ORDER BY #Unique_Results.RANK DESC\n" +

                        "DROP TABLE #Results\n" +
                        "DROP TABLE #Unique_Results\n")
                        .AddEntity("Account", typeof(Account));

                accounts = query.List<Account>();
            }

            return WebServiceQueryOptions<Account>.Apply(options, accounts);
        }
开发者ID:dblock,项目名称:sncore,代码行数:54,代码来源:WebAccountService.cs


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