- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我知道有一千个类似的问题,但我已经花了两周时间试图找到这个查询的真正解决方案。
此查询来自销售点计划。此查询与用户选择所需报告(期间、总计等)以及是否需要分组结果的表单相关。
这很不方便。查询是在 VB.NET 中生成的,我的意思是,通过代码生成,并且它将根据用户的选择(不同的总计、期间、组等)而变化,因此通过解决这个问题,我应该能够继续“创建"通过代码,表单的所有其他查询。
在本例中,该查询是按家庭分组的总计查询。
大部分时间 (>99%) 都浪费在发送数据上(显示查询 # 的配置文件)
表格如下:
CREATE TABLE `product` (
`idProduct` smallint(5) unsigned NOT NULL AUTO_INCREMENT,
`idFamily` tinyint(3) unsigned DEFAULT NULL,
`Codigo` char(10) NOT NULL,
`Nombre` char(70) DEFAULT NULL COMMENT 'Nombre corto',
-- five more integer columns
PRIMARY KEY (`idProduct`),
KEY `fk_p_idFamily` (`idFamily`),
CONSTRAINT `fk_p_idFamily` FOREIGN KEY (`idFamily`) REFERENCES `family` (`idFamily`),
) ENGINE=InnoDB AUTO_INCREMENT=19420 DEFAULT CHARSET=latin1 PACK_KEYS=0;
CREATE TABLE `family` (
`idFamily` tinyint(3) unsigned NOT NULL AUTO_INCREMENT,
`Nombre` char(30) NOT NULL,
`Descripcion` char(255) DEFAULT NULL,
`Borrado` tinyint(1) NOT NULL DEFAULT '0',
PRIMARY KEY (`idFamily`)
) ENGINE=InnoDB AUTO_INCREMENT=34 DEFAULT CHARSET=latin1 PACK_KEYS=0
CREATE TABLE `document` (
`idDocument` tinyint(3) unsigned NOT NULL AUTO_INCREMENT,
`Nombre` char(25) NOT NULL,
`Descripcion` char(100) DEFAULT NULL,
`Borrado` tinyint(1) NOT NULL DEFAULT '0',
`NoComputa` tinyint(1) NOT NULL DEFAULT '0',
`Rectifica` tinyint(1) NOT NULL DEFAULT '0',
`CalculoSumatorioPVP` tinyint(1) NOT NULL DEFAULT '0',
PRIMARY KEY (`idDocument`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=latin1 PACK_KEYS=0
CREATE TABLE `soldproduct` (
`idProduct` smallint(5) unsigned NOT NULL,
`idSale` int(10) unsigned NOT NULL,
`PrecioCompra` decimal(7,2) NOT NULL ,
`PrecioVenta` decimal(7,2) NOT NULL ,
`DtoProd` decimal(7,4) DEFAULT NULL ,
`BrutoUd` decimal(7,2) NOT NULL ,
`PVPUd` decimal(7,2) NOT NULL ,
`Cantidad` decimal(9,3) DEFAULT NULL ,
PRIMARY KEY (`idProduct`,`idSale`),
KEY `fk_pv_idSale` (`idSale`),
CONSTRAINT `fk_pv_idProduct` FOREIGN KEY (`idProduct`) REFERENCES `product` (`idProduct`),
CONSTRAINT `fk_pv_idSale` FOREIGN KEY (`idSale`) REFERENCES `sales` (`idSale`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 PACK_KEYS=0
CREATE TABLE `sales` (
`idSale` int(10) unsigned NOT NULL AUTO_INCREMENT,
`idDocument` tinyint(3) unsigned NOT NULL,
`idEstadoVenta` tinyint(3) unsigned NOT NULL,
`idCliente` smallint(5) unsigned NOT NULL,
`idFormaPago` tinyint(3) unsigned NOT NULL,
`idEmpleado` tinyint(3) unsigned NOT NULL ,
`idTienda` tinyint(3) unsigned DEFAULT NULL,
`idTipoVenta` tinyint(3) unsigned NOT NULL,
`FechaVenta` datetime DEFAULT NULL COMMENT 'Fecha de Venta',
`PrecioCompraTotal` decimal(10,2) DEFAULT NULL,
`IVA` decimal(7,4) DEFAULT NULL,
-- ten more decimal columns
-- five more datetime columns
-- ten more char columns
`Borrado` tinyint(1) NOT NULL DEFAULT '0' ,
`Historia` tinyint(1) NOT NULL DEFAULT '0',
PRIMARY KEY (`idVenta`),
KEY `fk_v_idTienda` (`idTienda`),
KEY `fk_v_idCliente` (`idCliente`),
KEY `fk_v_idEmpleado` (`idEmpleado`),
KEY `fk_v_idTipoVenta` (`idTipoVenta`),
KEY `fk_v_idFormaPago` (`idFormaPago`),
KEY `fk_v_idDocument` (`idDocument`),
KEY `fk_v_idEstadoVenta` (`idEstadoVenta`),
KEY `idx_v_FechaVenta` (`FechaVenta`),
CONSTRAINT `fk_v_idCliente` FOREIGN KEY (`idCliente`) REFERENCES `cliente` (`idCliente`),
CONSTRAINT `fk_v_idDocument` FOREIGN KEY (`idDocument`) REFERENCES `document` (`idDocument`),
CONSTRAINT `fk_v_idEmpleado` FOREIGN KEY (`idEmpleado`) REFERENCES `empleado` (`idEmpleado`),
CONSTRAINT `fk_v_idEstadoVenta` FOREIGN KEY (`idEstadoVenta`) REFERENCES `estadoventa` (`idEstadoVenta`),
CONSTRAINT `fk_v_idFormaPago` FOREIGN KEY (`idFormaPago`) REFERENCES `formapago` (`idFormaPago`),
CONSTRAINT `fk_v_idTienda` FOREIGN KEY (`idTienda`) REFERENCES `tienda` (`idTienda`),
CONSTRAINT `fk_v_idTipoVenta` FOREIGN KEY (`idTipoVenta`) REFERENCES `tipoventa` (`idTipoVenta`)
) ENGINE=InnoDB AUTO_INCREMENT=101770 DEFAULT CHARSET=latin1 PACK_KEYS=0
查询是这样的:
SELECT f.Nombre ,SUM(sp.PrecioVenta*sp.Cantidad)
FROM soldproduct sp, sales s, document doc, family f, product p
WHERE s.idDocument = doc.idDocument AND doc.NoComputa = FALSE
AND p.idProduct = sp.idProduct AND sp.idSale = s.idSale
AND p.idFamily = f.idFamily AND p.Borrado = FALSE
AND s.Borrado = FALSE AND s.Historia = FALSE AND s.idTienda = 1
AND s.FechaVenta BETWEEN '2013-01-01' AND '2014-01-01' GROUP BY f.idFamily;
我也尝试过这个(我还删除了文档表,以防它负责)
SELECT ProductFamily.Nombre, SUM(sp.PrecioVenta*sp.Cantidad)
FROM
(SELECT idSale FROM sales WHERE Borrado = FALSE AND Historia = FALSE AND idTienda = 1
AND FechaVenta BETWEEN '2013-01-01' AND '2014-01-01') SalesidSale
JOIN
soldproduct sp
ON sp.idSale = SalesidSale.idSale
JOIN
(SELECT p.idProduct, p.idFamily, f.Nombre FROM product p, family f WHERE
p.idFamily = f.idFamily AND p.Borrado = FALSE) ProductFamily
ON ProductFamily.idProduct = sp.idProduct
GROUP BY ProductFamily.idFamily;
花费的时间非常长,它对 EXPLAIN 命令的输出是(第一个查询):
id select_type table type possible_keys key key_len ref rows Extra
1 SIMPLE v range PRIMARY,fk_v_idTienda,fk_v_idDocument,idx_v_FechaVenta idx_v_FechaVenta 6 NULL 7387 "Using index condition; Using where; Using MRR; Using temporary; Using filesort"
1 SIMPLE doc ALL PRIMARY NULL NULL NULL 4 "Using where; Using join buffer (Block Nested Loop)"
1 SIMPLE pv ref PRIMARY,fk_pv_idSale fk_pv_idSale 4 gemalia.s.idSale 4 NULL
1 SIMPLE p eq_ref PRIMARY,fk_p_idFamily PRIMARY 2 gemalia.sp.idProduct 1 "Using where"
1 SIMPLE f eq_ref PRIMARY PRIMARY 1 gemalia.p.idFamily 1 NULL
我希望有人可以帮助我,我尝试创建索引、子查询等,但我无法得到低于 40 秒的任何内容,这太多了,而且我确信我做错了什么..
每个表的行数大约为:销量:10万产品:20,000家庭:35已售产品: 1,100,000文档:4
非常感谢。
最佳答案
尝试这个查询,我们试图在其中利用短路。
编辑
SELECT
f.Nombre,
SUM(sp.PrecioVenta*sp.Cantidad)
FROM
soldproduct sp
INNER JOIN
sales s
ON
(s.idTienda = 1 AND AND
s.Borrado = FALSE AND
s.Historia = FALSE AND
sp.idSale = s.idSale)
INNER JOIN
document doc
ON
(doc.NoComputa = FALSE AND
s.idDocument = doc.idDocument)
INNER JOIN
family f
ON
(p.idFamily = f.idFamily)
INNER JOIN
product p
ON
(p.Borrado = FALSE AND
p.idProduct = sp.idProduct)
WHERE
s.FechaVenta BETWEEN '2013-01-01' AND '2014-01-01'
GROUP BY
f.idFamily;
关于mysql - 优化 MySQL 查询以避免 “Using temporary” 和 “Using filesort”,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15807131/
我们已经有一个使用 AnyEvent 的库。它在内部使用 AnyEvent,并最终返回一个值(同步 - 不使用回调)。有什么方法可以将这个库与 Mojolicious 一起使用吗? 它的作用如下: #
我想从 XSD 文件生成带有 JAXB 的 Java 类。 问题是,我总是得到一些像这样的类(删除了命名空间): public static class Action { @X
我有一个关于 html 输入标签或 primefaces p:input 的问题。为什么光标总是自动跳转到输入字段。我的页面高度很高,因此您需要向下滚动。输入字段位于页面末尾,光标自动跳转(加载)到页
我今天在考虑面向对象设计,我想知道是否应该避免 if 语句。我的想法是,在任何需要 if 语句的情况下,您都可以简单地创建两个实现相同方法的对象。这两个方法实现只是原始 if 语句的两个可能的分支。
String graphNameUsed = graphName.getName(); if (graphType.equals("All") || graphType.equals(
我有一张友谊 table CREATE TABLE IF NOT EXISTS `friendList` ( `id` int(10) NOT NULL, `id_friend` int(10
上下文 Debian 64。Core 2 二人组。 摆弄循环。我使用了同一循环的不同变体,但我希望尽可能避免条件分支。 但是,即使我认为它也很难被击败。 我考虑过 SSE 或位移位,但它仍然需要跳转(
我最近在 Java 中创建了一个方法来获取字符串的排列,但是当字符串太长时它会抛出这个错误:java.lang.OutOfMemoryError: Java heap space我确信该方法是有效的,
我正在使用 (C++) 库,其中需要使用流初始化对象。库提供的示例代码使用此代码: // Declare the input stream HfstInputStream *in = NULL; tr
我有一个 SQL 查询,我在 WHERE 子句中使用子查询。然后我需要再次使用相同的子查询将其与不同的列进行比较。 我假设没有办法在子查询之外访问“emp_education_list li”? 我猜
我了解到在 GUI 线程上不允许进行网络操作。对我来说还可以。但是为什么在 Dialog 按钮点击回调上使用这段代码仍然会产生 NetworkOnMainThreadException ? new T
有没有办法避免在函数重定向中使用 if 和硬编码字符串,想法是接收一个字符串并调用适当的函数,可能使用模板/元编程.. #include #include void account() {
我正在尝试避免客户端出现 TIME_WAIT。我连接然后设置 O_NONBLOCK 和 SO_REUSEADDR。我调用 read 直到它返回 0。当 read 返回 0 时,errno 也为 0。我
我正在开发 C++ Qt 应用程序。为了在应用程序或其连接的设备出现故障时帮助用户,程序导出所有内部设置并将它们存储在一个普通文件(目前为 csv)中。然后将此文件发送到公司(例如通过邮件)。 为避免
我有一组具有公共(public)父类(super class)的 POJO。这些存储在 superclass 类型的二维数组中。现在,我想从数组中获取一个对象并使用子类 的方法。这意味着我必须将它们转
在我的代码中,当 List 为 null 时,我通常使用这种方法来避免 for 语句中的 NullPointerException: if (myList != null && myList.size
我正在尝试避免客户端出现 TIME_WAIT。我连接然后设置 O_NONBLOCK 和 SO_REUSEADDR。我调用 read 直到它返回 0。当 read 返回 0 时,errno 也为 0。我
在不支持异常的语言和/或库中,许多/几乎所有函数都会返回一个值,指示其操作成功或失败 - 最著名的例子可能是 UN*X 系统调用,例如 open( ) 或 chdir(),或一些 libc 函数。 无
我尝试按值提取行。 col1 df$col1[col1 == "A"] [1] "A" NA 当然我只想要“A”。如何避免 R 选择 NA 值?顺便说一句,我认为这种行为非常危险,因为很多人都会陷入
我想将两个向量合并到一个数据集中,并将其与函数 mutate 集成为 5 个新列到现有数据集中。这是我的示例代码: vector1% rowwise()%>% mutate(vector2|>
我是一名优秀的程序员,十分优秀!