- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试添加虚拟(不存在)行以获取系统中所有可用翻译的列表
我想要得到的是如下:(示例1)
id title source_langcode target_langcode | (type)----------------------------------------------------|... |205 Iriure EN en en | ⟵ original205 Iriure EN en de | ⟵ non translated (virtual)205 IriUKure en uk | ⟵ translation... |
What I'm having now:(example 2)
id title source_langcode target_langcode | ----------------------------------------------------|... |205 Iriure EN en en | ⟵ original 205 IriUKure uk DYMMY_LANGCODE | ⟵ translation205 Iriure EN en uk | ⟵ this is redundant205 Iriure EN en de | ⟵ non translated (virtual)...
Problem:translations
table stores only translated & original entities, but I need to add translations also for non translated entities, and this “virtual” records (their fields) should be based on source entity fields.
Overview:
There are two tables in this system
languages
- list of all available languages in the system (example 3)
id langcode----------------1 en2 de3 uk
translations
- list of source entities and their translations based on source entity (example 4)
id title langcode default_langcode created changed ... ...---------------------------------------------------------------------------------...205 Iriure EN en 1 xxxxxxxxxx xxxxxxxxxx205 IriUKure uk 0 xxxxxxxxxx xxxxxxxxxx206 UK Nunc UK uk 1 xxxxxxxxxx xxxxxxxxxx207 LucidusDE de 1 xxxxxxxxxx xxxxxxxxxx...
To indicate that current row is a source default_langcode
(int) column is used, in other case default_langcode
=> 0 means that this is a translation
Tried solutions:
One of the solution was using cross join on languages
table with default_langcode = 1
only rows but in this case I got fields from source entity on translated ones.I've used:
SELECT
translations.id AS id,
translations.title,
translations.langcode AS source,
translations.created AS created,
l.langcode,
tr.langs as translations_langs,
IF(FIND_IN_SET(l.langcode, tr.langs) AND translations.langcode <> l.langcode, 1, 0) as is_translation
FROM
translations translations
CROSS JOIN languages l
INNER JOIN (
SELECT
translations.id,
GROUP_CONCAT(translations.langcode separator ',') as langs,
COUNT(translations.langcode) as items
FROM translations translations
GROUP BY translations.id
) AS tr ON translations.id = tr.id
WHERE node_field_data.default_langcode = '1'
ORDER BY node_field_data.id
我尝试使用UNION的另一个解决方案,但在这种情况下,我得到的结果类似于示例1
,其中包含冗余行。
查询:
(SELECT
translations.id AS id,
translations.title,
translations.langcode AS source_language,
l.langcode as target_language,
translations.created AS created
FROM
translations translations
CROSS JOIN languages l
WHERE
translations.default_langcode = '1'
)
UNION ALL
(SELECT
translations.id AS id,
translations.title,
translations.langcode AS source_language,
'DYMMY_LANGCODE' as target_language ,
translations.created AS created
FROM
translations translations
WHERE
translations.default_langcode = '0'
)
ORDER BY id
摘要:我需要的只是获取所有语言和每种翻译语言代码之间的差异(其中 default_langcode
= 0),并从源实体(其中default_langcode
= 1)
就我个人而言,由于系统特定的原因,我宁愿不要使用联合,但如果这是唯一的方法,那么就可以了。理想情况下,我想使用带有连接的 translations
表。
协议(protocol):
行 ~ 实体 ~ 记录
感谢您的帮助!
最佳答案
试试这个(我没有运行,所以可能是语法错误)
SELECT t1.Id,
ISNULL(t.title,t1.title+'_'+t1.langcode) title,
t1.source_langcode,
t1.langcode target_langcode,
CASE
WHEN t1.default_langcode = t.langcode THEN '(original)'
WHEN t.langcode IS NULL THEN '(non translated)'
ELSE '(translation)'
END
FROM
(
--GET AllCodes trim suffix
SELECT t.Id,t.title,l.langcode,t.source_language
(SELECT Id,LEFT(title, LEN(title)-3) title, langcode source_language
FROM translations
WHERE default_langcode = 1
) t
JOIN lanquages ON 1=1
) t1
LEFT JOIN translations t ON t1.Id = t.Id AND t1.langcode = t.langcode
关于mysql - SQL 将 "non-existing"行添加到基于所有变体的结果中并删除重复项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47490956/
我正在使用 gmock 并模拟了一个函数 boost::beast::http::response_parser作为输出参数。功能签名看起来像: error_code readFromSocket(b
我的任务是打印由“非元音、元音、非元音”组成的单词列表,即 bab、bac、bad、bad ... 到 zuz。 我已经设法创建了一个代码,它执行前两个字母,但在最后一个循环中丢失并只打印'}' -
我正在尝试使用 label2rgb 生成 RGB 标签切片并使用它来更新 RGB 体积,如下所示: labelRGB_slice=label2rgb(handles.label(:,:,han
我有一个很奇怪的问题。我在 dll 中定义了一个接口(interface),如下所示: public interface IKreator2 { string Name { get; set;
在我的 openshift Drupal 托管中,网络都在 SSL 下 http://domain.com -> https://www.domain.com 确定 http://www.domain
我收到警告“退出构造函数时不可为空的事件‘SomeEvent’必须包含非空值。考虑将事件声明为可空。” 这是我的代码的一个非常简化的版本,它复制了完全相同的问题。我在这里错过了什么?这与 .Net 6
在一次大学考试中,我被要求测试一些 apache 簿记员类/方法,在这样做的过程中,我想在我的参数化测试中使用 mockito。没有 mockito 的测试工作正常但是当我尝试模拟接口(interfa
假设 A 列在 7 行中有以下值: 2 [空白的] 0 -0.3 0 [空白的] 0 如何获取范围(7 行)中非空/空白且不为零的最后一个值?因此,在这种情况下,正确答案是 -0.3。 最佳答案 =I
考虑以下受 this talk 启发的代码: template struct even_common_type_helper_impl; template struct even_common_typ
考虑这段代码, struct A {}; struct B { B(const A&) {} }; void f(B) { cout << "f()"<
考虑下面的类(class)。如果我对它运行 Findbugs,它会在第 5 行但不在第 7 行给我一个错误(“可序列化类中的非 transient 非可序列化实例字段”)。 1 public clas
我正在编写一个 python 脚本来计算 数据包丢失 通过使用 ping IP 地址linux 中的 subprocess 模块。 CSV 文件中保存了多个 IP 地址。当只给出可 ping 目的地时
我只是做文本更改,在文本之前它工作正常。请任何人都可以帮助我。 提前致谢 最佳答案 我已经解决了: ionic cordova 插件rmcordova-plugin-ionic-webview ion
我如何定义 在 persistence.xml 中? 我的项目在 Tomcat 6 和 Tomcat 7 中运行良好。 现在我正在使用 Struts 2 Spring 3.0.5 JPA 2 Jbos
我有一个 maven 仓库中不存在的第三方 jar,我们称它为“a.jar”,它也依赖于至少 20 多个第三方 jar,其中大部分不在 maven 中或者,我们称它们为“b.jar、c.jar、d.j
我已经浏览了各种线程很多小时(不夸张),但一直无法找到一种解决方案组合,使我能够将非 www 和 http 转发到 www 和 https,同时仍然能够查看 php 文件没有扩展名。如下是我的ngin
Scott Meyer 关于非成员函数增加封装并允许更优雅的设计(设计方面)的论点对我来说似乎非常有效。看这里:Article 但是我对此有疑问。 (似乎还有其他人,尤其是库开发人员,他们通常完全忽略
在对类设计的一些事实感到困惑时,特别是函数是否应该是成员,我查看了 Effective c++ 并找到了第 23 条,即 Prefer non-member non-friend functions
我正在尝试使用 firebase 云功能将通知发送到一个点半径的圆内的设备。我能够获取圈内设备的 ID,但无法获取 token ,使用 console.log(token) 打印时 token 为空。
我在我的项目中使用 React-ckeditor 5 包。我得到一个反序列化的 html 数据,我正在使用 React-html-parser 包将它解析成 html 模板,并将这个解析的数据传递给
我是一名优秀的程序员,十分优秀!