热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

查询处理器无法生成查询计划

查询处理器无法生成查询计划,因为需要工作表,且其最小的行大小超出了允许的%1!个字节的最大值。需要工作表通常是由于查询中有GROUPBY或ORDERBY子句..请各位大侠
查询处理器无法生成查询计划,因为需要工作表,且其最小的行大小超出了允许的 %1! 个字节的最大值。需要工作表通常是由于查询中有 GROUP BY 或 ORDER BY 子句.....

请各位大侠帮看一下这是什么问题?

5 个解决方案

#1


换个写法试试

#2


哎,这个是他们以前写的,现在客户那边出了问题,不太好改
造成这个问题的原因可以告诉我一下吗》?

#3


把写法贴出来

#4


sql.Append(" select *");
            sql.Append(" from (");
            sql.Append("        select '店面零售' as SellFlag, a.InputDate, a.InputDate as InputDateYM,");
            sql.Append("        e.CompanyNo,e.CompanyFullName,(case e.Active when 1 then '是' else '否'end ) 公司可用, d.ShopNo, d.ShopFullName,(case d.Active when 1 then '是' else '否' end)店面可用,");
            sql.Append("        f.BigRegionName, f.ProvinceName, f.CityName, f.CountyName, f.TownName,");
            sql.Append("        '' as DestCompanyId, '' as DestCompanyName,");
            sql.Append("        '' as DestBigRegionName, '' as DestProvinceName, '' as DestCityName,  '' as DestCountyName, ");
            sql.Append("        '' as DestTownName,");
            if (rpSubProductLineId != "-1")
            {
                sql.Append("    rp.rpSubProductLine as ProductLine,");
            }
            else
            {
                sql.Append("        c.ProductLine,");
            }
            sql.Append("        p.ProductGroupName,b.ProductModel,b.ProductNum,b.ProductType,ps.ProductSeries,(case b.Active when 1 then '是' else '否' end)产品可用,a.SelloutQty as SelloutQty");
            sql.Append("        from FactShopSellout a  ");
            sql.Append("        inner join DimProduct b   on a.ProductId = b.ProductId   ");
            sql.Append("        inner join DimProductLine c   on b.ProductLineId = c.ProductLineId ");
            sql.Append("        inner join DimRPSubProductLine rp on b.RPSubProductLineId = rp.RPSubProductLineId ");
            sql.Append("        inner join DimShop d   on a.ShopId = d.ShopId   ");
            sql.Append("        inner join DimCompany e   on d.CompanyId = e.CompanyId and isKP=0 ");
            sql.Append("        inner join RelCompanyWith3T r   on e.CompanyId = r.CompanyId and  rp.RPSubProductLineId=r.RPSubProductLineId and r.Active=1");
            sql.Append("        left join DimProductGroup p on b.ProductGroupId=p.ProductGroupId ");
            sql.Append("        left join DimProductSeries ps on b.ProductSeriesId = ps.ProductSeriesId ");
            sql.Append("        inner join vGeography f   on e.TownId = f.TownId   ");
            sql.Append("        where 1=1  ");
            sql.Append("        and a.InputDate BETWEEN  '" + beginInputDate + "' and '" + endInputDate + "' ");
            sql.Append("        and c.ProductLineId = ");
            sql.Append("        (" + productLineId + ") ");
            sql.Append("        and b.ProductType IN ");
            sql.Append("        (" + ProductType + ") ");
            sql.Append("        and b.Active IN ");
            sql.Append("        (" + productActive + ") ");
            sql.Append("        and b.ProductGroupId IN ");
            sql.Append("        (" + productGroup + ") ");
            sql.Append("        and isnull(b.ProductSeriesId,'') IN ");
            sql.Append("        (" + productSeriesId + ") ");
            if (rpSubProductLineId != "-1")
            {
                sql.Append(" and b.rpSubProductLineId=" + rpSubProductLineId);
            }
            if (bigRegionId != -1)
            {
                sql.Append(" and f.BigRegiOnId=" + bigRegionId);
            }
            if (regionId != -1)
            {
                sql.Append(" and f.RegiOnId=" + regionId);
            }
            if (provinceId != -1)
            {
                sql.Append(" and f.ProvinceId=" + provinceId);
            }
            if (rtCityId != -1)
            {
                sql.Append(" and f.CityId=" + rtCityId);
            }
            if (companyId != -1)
            {
                sql.Append(" and e.companyId=" + companyId);
            }

            sql.Append("        union all");
            sql.Append("        select '公司批发' as SellFlag, a.InputDate, a.InputDate as InputDateYM, ");
            sql.Append("        e.CompanyNo,e.CompanyFullName,(case e.Active when 1 then '是' else '否'end ) 公司可用, '' as ShopNo, '' as ShopFullName,'' as 店面可用,");
            sql.Append("        f.BigRegionName, f.ProvinceName, f.CityName,  f.CountyName,f.TownName, ");
            sql.Append("        i.ResellerNo as DestCompanyId, i.FullName as DestCompanyName,");
            sql.Append("        j.BigRegionName as DestBigRegionName, j.ProvinceName as DestProvinceName, j.CityName as DestCityName, ");
            sql.Append("        i.CountyName as DestCountyName,i.TownName as DestTownName,");
            if (rpSubProductLineId != "-1")
            {
                sql.Append("    rp.rpSubProductLine as ProductLine,");
            }
            else
            {
                sql.Append("        c.ProductLine,");
            }
            sql.Append("        p.ProductGroupName,b.ProductModel,b.ProductNum,b.ProductType,ps.ProductSeries,(case b.Active when 1 then '是' else '否' end)产品可用, ");
            sql.Append("        a.SellthruQty as SelloutQty  ");
            sql.Append("        from Fact3TCompanySellthru a  ");
            sql.Append("        inner join DimProduct b   on a.ProductId = b.ProductId   ");
            sql.Append("        inner join DimProductLine c   on b.ProductLineId = c.ProductLineId ");
            sql.Append("        inner join DimRPSubProductLine rp on b.RPSubProductLineId = rp.RPSubProductLineId ");
            sql.Append("        inner join DimCompany e   on a.CompanyId = e.CompanyId");
            sql.Append("        inner join vGeography f   on e.TownId = f.TownId   ");
            sql.Append("        left join vMixResellerWithDimReseller i on a.DestMixResellerId = i.MixResellerId  ");
            sql.Append("        left join vCountyGeography j   on i.CountyId = j.CountyId    ");
            sql.Append("        left join RelResellerWith3Ttype k on i.ResellerId = k.ResellerId and b.ProductLineId = k.ProductLineId ");
            sql.Append("        left join DimProductGroup p on b.ProductGroupId=p.ProductGroupId ");
            sql.Append("        left join DimProductSeries ps on b.ProductSeriesId = ps.ProductSeriesId ");

下面还有一些就是条件了。

#5


请各位大侠帮帮忙啊
很急啊

推荐阅读
  • 本文介绍了如何在MySQL中将零值替换为先前的非零值的方法,包括使用内联查询和更新查询。同时还提供了选择正确值的方法。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • 本文介绍了九度OnlineJudge中的1002题目“Grading”的解决方法。该题目要求设计一个公平的评分过程,将每个考题分配给3个独立的专家,如果他们的评分不一致,则需要请一位裁判做出最终决定。文章详细描述了评分规则,并给出了解决该问题的程序。 ... [详细]
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
  • 本文介绍了在MySQL8.0中如何查看性能并解析SQL执行顺序。首先介绍了查询性能工具的开启方法,然后详细解析了SQL执行顺序中的每个步骤,包括from、on、join、where、group by、having、select distinct、union、order by和limit。同时还介绍了虚拟表的概念和生成过程。通过本文的解析,读者可以更好地理解MySQL8.0中的性能查看和SQL执行顺序。 ... [详细]
  • 本文介绍了Oracle存储过程的基本语法和写法示例,同时还介绍了已命名的系统异常的产生原因。 ... [详细]
  • Postgresql备份和恢复的方法及命令行操作步骤
    本文介绍了使用Postgresql进行备份和恢复的方法及命令行操作步骤。通过使用pg_dump命令进行备份,pg_restore命令进行恢复,并设置-h localhost选项,可以完成数据的备份和恢复操作。此外,本文还提供了参考链接以获取更多详细信息。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 3.223.28周学习总结中的贪心作业收获及困惑
    本文是对3.223.28周学习总结中的贪心作业进行总结,作者在解题过程中参考了他人的代码,但前提是要先理解题目并有解题思路。作者分享了自己在贪心作业中的收获,同时提到了一道让他困惑的题目,即input details部分引发的疑惑。 ... [详细]
  • Go Cobra命令行工具入门教程
    本文介绍了Go语言实现的命令行工具Cobra的基本概念、安装方法和入门实践。Cobra被广泛应用于各种项目中,如Kubernetes、Hugo和Github CLI等。通过使用Cobra,我们可以快速创建命令行工具,适用于写测试脚本和各种服务的Admin CLI。文章还通过一个简单的demo演示了Cobra的使用方法。 ... [详细]
  • ubuntu用sqoop将数据从hive导入mysql时,命令: ... [详细]
  • 本文讨论了如何使用IF函数从基于有限输入列表的有限输出列表中获取输出,并提出了是否有更快/更有效的执行代码的方法。作者希望了解是否有办法缩短代码,并从自我开发的角度来看是否有更好的方法。提供的代码可以按原样工作,但作者想知道是否有更好的方法来执行这样的任务。 ... [详细]
  • 本文讨论了如何在codeigniter中识别来自angularjs的请求,并提供了两种方法的代码示例。作者尝试了$this->input->is_ajax_request()和自定义函数is_ajax(),但都没有成功。最后,作者展示了一个ajax请求的示例代码。 ... [详细]
author-avatar
--Zqf
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有