- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我有一个用于查找的表,它在一列中存储人类可读的值,在另一列中存储去除特殊字符和空格的相同文本。例如,值“Children's Shows”将在查找列中显示为“childrens-shows”。
不幸的是,相应的主表并不是那么简单 - 由于历史原因,我没有自己创建,现在很难撤消,查找值实际上存储在周围的星号中,例如'* child 节目*'。
因此,在尝试将无星号查找表与带星号的主表连接时,我认为 CONCAT 会帮助我即时添加它们,例如;
SELECT *
FROM main_table m
INNER JOIN lookup_table l
ON l.value = CONCAT('*',m.value,'*')
... 然后 table 就烤好了。不确定我是创建了一个无限循环还是真的搞砸了数据,但它需要 ISP 备份才能让表再次响应。我怀疑这是因为“*”符号可能是保留的,就像通配符一样,我已经要求数据库做相当于舔自己肘部的事情。无论哪种方式,鉴于它设法杀死数据库的壮观方式,我都不愿“试验”以找到答案。
提前感谢任何可以 (a) 告诉我上面对数据库实际做了什么,以及 (b) 我应该如何实际加入表的人?
最佳答案
当使用CONCAT时,mysql不会使用索引。使用 EXPLAIN 来检查这个,但我最近遇到的一个问题是在一个大表上,索引列在那里,但没有使用键。然而,这不应该让整个表格变得乏味,只是让它变慢。可能它用完了内存,开始交换然后中途崩溃,但您需要检查日志才能找出答案。
然而,根本原因显然是糟糕的表设计,而这正是解决方案所在。您得到的任何允许您解决此问题的答案最多只能是暂时的。
最好的解决方案是将这些数据移到一个单独的表中。 “ child 节目”听起来像一个类别,因此在许多行中重复数据。这实际上应该是“类别”表的 id,这将防止数据库必须在表中的每一行上运行 CONCAT,因为您可以这样做:
SELECT *
FROM main_table m
INNER JOIN lookup_table l
ON l.value = m.value
/* and optionally */
INNER JOIN categories cat
ON l.value = cat.id
WHERE cat.name = 'whatever'
我知道根据您在问题中提供的信息,您可能无法做到这一点,但实际上无法对规范化程度很差的数据库进行此类更改的原因比此处的代码更重要。如果没有资源或政治支持来以正确的方式做事,你最终会遇到更多像这样令人头疼的事情,从长远来看,最终会付出更多代价。也许是时候和老板谈谈了:)
关于MySQL CONCAT '*' 符号向数据库 toast ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12931771/
数据库设置: http://sqlfiddle.com/#!2/4d1c2/1 以下查询选择属于productID的所有标签及其位置,逗号分隔: SELECT CONCAT_WS(',', GROUP
要连接两个文件,它看起来像这样: concat: { src: ['common.js','js/app.js'], dest: 'assets/js/app.js' } 如果
我有一个执行 SQL 脚本的 PDI(Kettle)转换,脚本的输出是一列,如下所示: val1 val2 val3 val4 "more values"... 我需要像这样在一个 Excel 单元格
我正在尝试传递一个参数 [例如@X nvarchar(MAX)] 转换成变量 [例如@message nvarchar(MAX)] 在存储过程中。该变量使用 CONCAT 组合字符串值和变量,它最终成
我不知道如何解释我的问题... 这是我的sql请求: SELECT DISTINCT CONCAT (nompropre, ' ', Auteur, ' de ', localite) AS aute
如何在与另一个表连接的表中使用 concat 和 group concat。架构如下所示: 第一表: MariaDB [ittresnamuda]> select * from tb_tipe_req
在我的 CREATE VIEW 中,我想: SELECT CONCAT( t.str1, t.str2 ) AS Title, CHAR_LENGTH( Title ) AS Length 但这会产生
我正在使用 CriteriaBuilder.concat 连接 2 个字符串,代码如下: Expression concat = criteriaBuilder.concat(expr1, expr2
我有以下继承 IEnumerable 的类 public class LinesEnumerable : IEnumerable { protected readonly IPointSeri
_.concat 和有什么区别lodash 和 Array.prototype.concat() ?. 最佳答案 欢迎来到 Stackoverflow! 这些函数的工作方式相同,但语法不同: _.co
我有一个非常大的表(几百万条记录)。表中的列 A 目前是这样的:id、道路名称、纬度、经度,其中 id 是自动增量 PK。 目前,1 个道路名称可以在表中包含多个条目,因为每条道路都映射到多个(纬度、
我测试了各种数组连接技术,并不是因为它实际上对我的代码很重要,而只是顺便说一句,看看我们现在在哪里。正如预期的那样,非常新的 ES 2015 传播运算符在 JavaScript 数组上被旧的 conc
我有一个数组,我需要使用一些编辑重新编译。我是在 async.concat() 的帮助下完成的,但有些东西不起作用。告诉我,哪里错了? async.concat(dialogs, function(d
在 JavaScript 中,我遇到过以两种主要方式编写的代码,用于连接两个(或更多)使用 .concat() 的数组。 Array 上的方法目的。 (假设在下文中,arr1 和 arr2 是作为 .
我之前曾使用 stack over flow 来解决我的 sql 问题并且成功了。 这一次我的下一期可能不会那么成功。 我有一个名为 Statements_1 的表,该表大约有 50 列,假设有 10
我在想以一种相当奇怪的方式从数据库获取东西时遇到了一些麻烦。假设我有下一张 table ID | Rating 229 | 3 229 | 2 229 | 4 229 | 2 2
我有类似表中的内容 mysql> select uuid , short-uuid FROM sampleUUID WHERE identifier ="test123"; +------------
我有一个查询,用于获取我离开加入两个表的帖子: 类别和标签:LEFT JOIN 到链接表→‖INNER JOIN 到类别和标签名称表。 LEFT JOIN wp_term_relationships
我目前正在开发一个大型 angular.js 项目。我使用 grunt 将所有文件合并/丑化为一个大的 target.js 文件,然后将其包含在索引页中。 我已经意识到,这使得在开发环境中调试变得非常
我的表中有三列:firstName、lastName 和 jobTitle。我想将 firstName 和 lastName 连接为 Fullname,然后连接 Fullname 和 jobTitle
我是一名优秀的程序员,十分优秀!