- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我想知道是否在 MySQL 查询中使用 CASE ... WHEN ... THEN 表达式
对性能有负面影响吗?
而不是使用 CASE 表达式(例如在您的 UPDATE 查询中)
你总是有可能在你的程序中做 if else 语句
用 php、python、perl、java 编写,...选择要发送的查询,例如(伪代码):
prepareStatement(
"UPDATE t1 SET c1=c1+1, msg=CASE (@v:=?) WHEN '' THEN msg ELSE @v END"
);
setStatementParameter(1, message);
或欧洲工商管理学院:
if (message == "") {
prepareStatement("UPDATE t1 SET c1=c1+1");
} else {
prepareStatement("UPDATE t1 SET c1=c1+1, msg=?");
setStatementParameter(1, message);
}
(这里需要 c1 只是为了表明在这两种情况下都会发生某些事情)
哪种方式性能更好?
性能损失是多少?
最佳答案
几乎所有每行函数都会对性能产生影响,唯一真正的问题是:“影响是否小到不必担心?”。
这是您应该通过测量而不是猜测来发现的东西。如果您的数据和查询都没有改变,那么数据库管理只是一种一劳永逸的事件。否则,您应该定期监控性能以确保不会出现问题。
上述评论中的“足够小”,我的意思是,您可能不必担心以下内容对性能的影响:
select * from friends where lowercase(lastname) = "smith"
如果你只有三个 friend 。
随着表的大小增加,这些事情的影响变得更加严重。例如,如果您有 1 亿客户,并且您想要找到所有可能与计算机相关的客户,您就不会想尝试:
select name from customers where lowercase(name) like '%comp%'
这可能会让您的 DBA 对您大打出手。
我们过去解决此问题的一种方法是在数据中引入冗余。使用第一个示例,我们将添加一个名为 lowerlastname
的额外列,并用 lastname
的小写值填充它。然后为搜索目的编制索引,您的 select
语句将变得快得令人眼花缭乱,正如它们应该的那样。
这对我们深爱的 3NF 有什么影响,我听到你问了?如果您知道自己在做什么,答案是“不多”:-)
您可以设置数据库,使这个新列由插入/更新触发器填充,以保持数据一致性。出于性能原因破坏 3NF 是完全可以接受的,前提是您了解并减轻后果。
同样,第二个查询可以有一个插入/更新触发器,每当更新或插入包含相关文本的条目时,该触发器就会填充新的索引列 name_contains_comp
。
由于大多数数据库的读取频率远高于写入频率,因此这会将计算成本转移到插入/更新,从而有效地将其分摊到所有选择操作中。查询将是:
select name from customers where name_contains_comp = 'Y'
同样,您会发现查询速度快得令人眼花缭乱,而插入和更新速度稍慢的代价很小。
关于mysql - MySQL 中的 CASE 性能?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7722423/
我经常在 ATS 中看到使用 case、case+ 或 case- 形成的 case 表达式。有什么区别? 最佳答案 如果表达式不详尽,使用 case 会发出警告,case+ 会产生错误,而 case
我有一个导入时全部大写的表,我想将其转换为正确的大小写。你们用什么脚本来完成这个? 最佳答案 这个函数: “正确大小写”由空格分隔的所有“大写”单词 保留“小写单词” 即使对于非英语字母也能正常工作
#include int main() { switch(2) { case 1: if(1)
我已经四处寻找了一段时间,如果我使用的术语不当,请原谅我... 代码的目标是在输入为 0 时更新 Aout1 和 Aout0,输出对应于 7 段显示,但出现以下错误: “错误 (10170):Four
我正在尝试按照 PostgreSQL 手册中的说明进行操作。 PostgreSQL: Documentation: 9.1: Control Structures 我的 PostgreSQL 服务器是
我有一个状态机,其中有几个非常相似的状态。我可以为每个状态编写它,如下例所示: module CHECK_FSM ( GO, DONE, CLK, RESETN ); input GO;
如何使用或创建案例? 就像是: string str; case (str) "abc" || "dfg": begin //some code end "yfg":
这个问题已经有答案了: Are double and single quotes interchangeable in JavaScript? (23 个回答) 已关闭 9 年前。 我正在学习Java
汽车 Make | Model | Year | Color Honda | Accord | 12 | Red Lexus | IS | 14 |
如何使用当前 case 语句的值跳转到 switch-case 条件下的另一个 case 语句? 是否可以使用 switch case 来实现这种事情,或者是否有其他实现方式? 有可能实现吗?如果没有
我理解下面的代码。 var day = 2; switch (day) { case 1: document.write("Monday"); break;
这是有效的。 object FilesToDFDS { case class Student(id: Int, name: String, dept:String) def main(
我对 VHDL 还是个新手。我需要在 CASE 语句中为多个信号赋值,如下所示: CASE input24 IS WHEN "00" THEN output0
我有这个 case 语句,它给出了一个错误“变量 constant1 未使用”。它似乎忽略了变量并返回了第一行,因此变量显然没有范围。如果我用数字 1 替换常量,那么它就可以工作。在 Elixir 中
在 MySQL 中,是否可以在 SELECT 子句中有两个 CASE 语句,其中第二个 CASE 语句依赖于第一个 CASE 语句? 例如,考虑以下查询: SELECT CASE WHEN `user
我正在尝试一个挑战,我需要获得一个随机数,并在没有重复的情况下打印数字内的数字总和:例如,123 将打印 6 ( 1 + 2 + 3 ),而 32111 将做同样的事情(因为我们没有在我们的总和中添加
当有人试图更新当前未存储在我的散列中的值时,我想立即返回 when 'add' 而无需重新启动整个 case声明,因为我已经知道他们想要添加并且不想再次提示他们。 有没有一种方法可以在不重新启动整个案
老 C 程序员可以在 Swift 方面得到一些帮助。 我不太了解 if-case 语法。例如: if case 20...30 = age { print ("in range.") } cas
老 C 程序员可以在 Swift 方面得到一些帮助。 我不太了解 if-case 语法。例如: if case 20...30 = age { print ("in range.") } cas
我有一个 ArrayList,其中包含以下字符串:[name, age, gender, salary] . 有没有办法可以将 ArrayList 中的值用作 case 表达式? 显而易见的答案是否定
我是一名优秀的程序员,十分优秀!