- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个表格,其中包含一次性优惠券代码的库存。每行都是一个单独的代码。为简单起见,表格如下所示:
| id (AUTO_INCREMENTING) | owner (VARCHAR) | brand (VARCHAR) | currency (CHAR) | value (INTEGER) | activated_at (TIMESTAMP) | expires_at (DATE) |
|------------------------|-----------------|-----------------|-----------------|-----------------|--------------------------|-------------------|
| 1 | first-owner | brand-one | gbp | 10 | NULL | 2018-06-06 |
| 2 | second-owner | brand-one | gbp | 15 | NULL | 2018-06-06 |
| 3 | second-owner | brand-one | gbp | 15 | NULL | 2018-06-06 |
我知道我可以规范化表并将所有字段提取到它们自己的表中,并且让 stock
表只包含 ids
,但是到目前为止尚未证明可以提高性能,并且为了简单性和用户可读性,我倾向于保持原样。
查询此表时,我希望能够有选择地传递所有者、品牌或两者。
对于以下查询,我需要在此表上使用哪些索引?为什么?
查询表格而不提供所有者或品牌:
SELECT
`owner`,
`brand`,
`currency`,
`value`,
count(*) AS 'quantity_of_codes',
(count(*) * `value`) AS 'total_face_value'
FROM `inventory`
WHERE `activated_at` IS NULL
AND `expires_at` >= '2018-06-05'
GROUP BY `owner`, `brand`, `currency`, `value`
如果我运行 explain
我可以看到使用了索引:
| select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
|-------------|-----------|------|---------------|-----|---------|-------|--------|-----------------------------------------------------------|
| SIMPLE | inventory | ref | | | 766 | const | 416144 | Using where; Using index; Using temporary; Using filesort |
当我提供一个 owner 时,会使用索引,但它会创建一个临时表并使用 filesort,我认为这不太好。
SELECT
`brand`,
`owner`,
`currency`,
`value`,
count(*) AS 'quantity_of_codes',
(count(*) * `value`) AS 'total_face_value'
FROM `inventory`
WHERE `owner` = 'first-owner'
AND `activated_at` IS NULL
AND `expires_at` >= '2017-06-06'
GROUP BY `brand`, `owner`, `currency`, `value`
运行 explain
显示:
| select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
|-------------|-----------|-------|----------------------------------------------------------|----------------------------------------------------------|---------|-----|------|-----------------------------------------------------------|
| SIMPLE | inventory | index | brand_owner_currency_value_activated_at_expires_at_index | brand_owner_currency_value_activated_at_expires_at_index | 2310 | | 87 | Using where; Using index; Using temporary; Using filesort |
当我还提供一个品牌时,我得到:
SELECT
`brand`,
`owner`,
`currency`,
`value`,
count(*) AS 'quantity_of_codes',
(count(*) * `value`) AS 'total_face_value'
FROM `inventory`
WHERE `owner` = 'first-owner'
AND `brand` = 'brand-one'
AND `activated_at` IS NULL
AND `expires_at` >= '2018-06-05'
GROUP BY `brand`, `owner`, `currency`, `value`
最后,当我运行 explain
时,我得到:
| select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
|-------------|-----------|------|----------------------------------------------------------|----------------------------------------------------------|---------|-----|------|-----------------------------------------------------------|
| SIMPLE | inventory | ref | brand_owner_currency_value_activated_at_expires_at_index | brand_owner_currency_value_activated_at_expires_at_index | 1532 | | 1 | Using where; Using index; Using temporary; Using filesort |
如前所述,我有一个涵盖品牌、所有者、货币、值(value)、activated_at 和 expires_at 字段,尽管当我不在查询的 where 部分包含 brand 时不会使用它。
最佳答案
http://use-the-index-luke.com/是一个很好的引用,可以帮助你熟练地设计索引。
通过为此类查询选择复合索引,您走在了正确的轨道上。您的查询包含这些 WHERE
子句项。
WHERE `owner` = 'an-owner'
AND `activated_at` IS NULL
AND `expires_at` >= '2017-06-06'
您在第一项上寻找相等性,在第二个上寻找 IS NULL
,在第三个上寻找范围扫描。因此,(owner, activated_at, expires_at)
上的索引可以让查询计划程序跳转到正确的行,然后扫描索引以查找连续的行。 (activated_at, owner, expires_at)
上的索引也将起作用。
您在 (brand, owner, currency, value, _activated_at, _expires_at)
上的索引无法针对您显示的查询进行范围扫描。所以查询规划器会忽略它。
专业提示:不要仅仅因为它们看起来很有用就为表创建索引。设计它们以加快您需要加快的查询速度。
专业提示#2:使用临时;使用 filesort 并不是性能不佳的明确标志。 临时 意味着一些结果集需要放入服务器中一个临时的类似表的数据结构中。 filesort 表示结果集在传递前需要排序。当您使用 GROUP BY
时,查询规划器通常需要一个临时 结构来完成您的查询。读这个。 https://www.percona.com/blog/2009/03/05/what-does-using-filesort-mean-in-mysql/
你的 EXPLAIN
输出对我来说看起来非常好。一排?太好了,
关于mysql - 以下场景需要哪些索引,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44388892/
websocket的用途/场景 先总结:高即时性服务,比如聊天室的群聊,server顺序收到了张三,李四的消息,立即就推送给王五,不能让王五等半天。 Ajax也可以一秒一刷,让王五去问张三说话没,如果
前端的工作过程里,本地开发、提供测试环境,总得有个用着顺手的服务器软件,这个场景里nginx很流行。 介绍两个好用的配置项:rewrite try_files @xxxx rewrite 比较
我有一个场景的两个不同角度的 2 个视频文件,我想重建场景的 3D 估计。它类似于 3D 传感器的作用(例如 Kinect、PrimeSense)。我正在寻找一个库,甚至是一个完善的机器视觉算法,以便
我已阅读RebaseProject页面并尝试了一个不平凡的例子(不是对一个完整的分支进行 rebase )。这与 rebase D 的情况类似我场景B。 这是rebase之前的情况: default
有没有办法将我的场景保存在 JavaFx 应用程序中单独的 Java 文件中?我尝试过这样的事情: public class MyApp extends Application { pri
我有这样的场景:用户想要查看大量有关自己的信息。例如:年龄、姓名、地位、收入、工作、爱好、 child 的名字、妻子的名字、酋长的名字、祖父/祖母的名字。大约 50 个变量。他可以选择任何变量来显示信
我希望有人能帮助我解决这个问题:我有一个包含条目的表。我想执行查询并根据模式获取得分最高的记录。模式将是:如果我的话按原样出现,那么该条目的分数将是最高的。如果该单词出现在句子中,则该条目的分数将低于
我正在尝试在我的应用程序委托(delegate)方法中实现一些逻辑。了解当前正在运行哪种场景将非常有帮助。 [[CCDirector sharedDirector] runningScene] 返回当
好的,这是一个有趣的。我有 2 个表:tbl_notes、tbl_notes_categories 简单地说,tbl_notes 有一个 categoryid,我将 2 个表与该 ID 相关联。所以,
我有一个使用并行运行的 Specflow、selenium、NUnit 的测试解决方案在 AssemblyInfo 中添加了这个:[程序集:Parallelizable(ParallelScope.F
我正在尝试弄清楚如何在 SpriteKit 中添加更多场景。如果我在 GameViewController 中使用 SpriteKit 生成的行 if let scene = GameScene.un
目录 1、业务背景 2、场景分析 3、流程设计 1、业务流程 2、导入流程
我是 Unity 的新手,所以修复起来可能非常简单。我使用了一个 3D Google SketchUp 模型,我想让玩家环顾模型。 super 简单。 我添加了 3D 平面,添加了相机并更新了设置以支
我需要标记要跳过的某些测试。但是,有些测试是参数化的,我只需要能够跳过某些场景。 我使用 py.test -m "hermes_only" 调用测试或 py.test -m "not hermes_o
我已经开始使用 SpecFlow 并想知道是否可以在规范之间重用场景 基本上我的想法是这样的(我可能从根本上是错误的:)) 我编写了一项功能来验证导航。 功能:导航 I should be able
在编写验证输入表单上的信息的 BDD 场景时,您将如何列出规则。 选项是: 1) 每个规则一个场景 2)场景大纲,每个领域和规则的例子 我们如何说某些不在特定字符集中的无效内容,例如: 鉴于我输入了一
我们如何使用 StoryQ 来测试预期出现异常的场景? 最佳答案 就实际代码而言,在测试代码的 .Then 部分,您需要创建一个 Action 或 Func 来确定正在测试的内容,然后在代码的 .Th
完成快速初学者努力通过点击按钮向场景添加节点。 我知道我可以使用点击手势来获取点击坐标并执行点击测试,然后在点击的 3D 空间中放置一个对象。但是,我想在设备屏幕的中央显示一个球体或十字准线,当点击屏
如何在表格中传递空格? Background: Given the following books |Author |(here several spaces)
我正在尝试从 Eric Haines' Standard Procedural Database (SPD) 渲染“mount”场景,但折射部分就是不想配合。我已经尝试了所有我能想到的方法来修复它。
我是一名优秀的程序员,十分优秀!