假设您需要从“settings”表中检索默认设置,但还需要包含被覆盖的角色设置。但是,您现有的查询只检索明确设置角色的设置,不包括默认值。
为了解决这个问题,我们可以修改查询以获得所需的结果。我们不通过 WHERE 子句进行过滤(这会排除左连接失败的行),而是将条件移到连接本身:
<code class="language-sql">SELECT `settings`.*, `character_settings`.`value` FROM `settings` LEFT JOIN `character_settings` ON `character_settings`.`setting_id` = `settings`.`id` AND `character_settings`.`character_id` = '1' </code>
通过将条件移到连接中,我们确保只有在存在特定于角色的设置时,左连接才会成功,如果尚未覆盖,则仍然保留默认设置。这将产生所需的结果:
<code class="language-php">array( '0' => array('somekey' => 'keyname', 'value' => 'thevalue'), '1' => array('somekey2' => 'keyname2'), '2' => array('somekey3' => 'keyname3') )</code>
其中键 1 和 2 代表默认值,键 0 包含用特定于角色的值增强的默认值。
以上是如何使用 LEFT JOIN 检索默认设置和特定于字符的覆盖?的详细内容。更多信息请关注PHP中文网其他相关文章!