<span><span><span class="hljs-meta"><?php</span></span><span>
</span><span><span class="hljs-comment">// 方法を示す方法は次のとおりです PHP で使用されます mysqli 複数のデータベース接続を確立し、文字セットを確認します</span></span><span>
</span><span><span class="hljs-comment">// 知らせ:この部分はテキストとは何の関係もありません,たとえば、のみ</span></span><span>
</span><span><span class="hljs-variable">$mysqli1</span></span><span> = </span><span><span class="hljs-keyword">new</span></span><span> </span><span><span class="hljs-title function_ invoke__">mysqli</span></span><span>(</span><span><span class="hljs-string">"localhost"</span></span><span>, </span><span><span class="hljs-string">"user1"</span></span><span>, </span><span><span class="hljs-string">"pass1"</span></span><span>, </span><span><span class="hljs-string">"db1"</span></span><span>);
</span><span><span class="hljs-variable">$mysqli2</span></span><span> = </span><span><span class="hljs-keyword">new</span></span><span> </span><span><span class="hljs-title function_ invoke__">mysqli</span></span><span>(</span><span><span class="hljs-string">"localhost"</span></span><span>, </span><span><span class="hljs-string">"user2"</span></span><span>, </span><span><span class="hljs-string">"pass2"</span></span><span>, </span><span><span class="hljs-string">"db2"</span></span><span>);
</span><span><span class="hljs-keyword">if</span></span><span> (</span><span><span class="hljs-variable">$mysqli1</span></span><span>->connect_error || </span><span><span class="hljs-variable">$mysqli2</span></span><span>->connect_error) {
</span><span><span class="hljs-keyword">die</span></span><span>(</span><span><span class="hljs-string">"データベース接続に失敗しました"</span></span><span>);
}
</span><span><span class="hljs-comment">// 接続された2つの文字セット名を印刷します</span></span><span>
</span><span><span class="hljs-keyword">echo</span></span><span> </span><span><span class="hljs-string">"接続する1文字セット:"</span></span><span> . </span><span><span class="hljs-variable">$mysqli1</span></span><span>-></span><span><span class="hljs-title function_ invoke__">character_set_name</span></span><span>() . PHP_EOL;
</span><span><span class="hljs-keyword">echo</span></span><span> </span><span><span class="hljs-string">"接続する2文字セット:"</span></span><span> . </span><span><span class="hljs-variable">$mysqli2</span></span><span>-></span><span><span class="hljs-title function_ invoke__">character_set_name</span></span><span>() . PHP_EOL;
</span><span><span class="hljs-meta">?></span></span><span>
---
</span><span><span class="hljs-comment"># 存在する多个数据库接続する下如何使用 mysqli::character_set_name 确保文字セット一致?</span></span><span>
存在する PHP の Web 開発中,我们经常会同时接続する多个数据库。例えば,データベースはユーザーデータを保存します,別のデータベースは、ログまたはレポートに使用されます。存在する这种情况下,如果不同の数据库接続する使用了不一致の文字セット,これにより、文字化けされたコードが保存されて読み取られる可能性があります。、異常または安全上の危険さえ。したがって,合理的な使用 **`mysqli::</span><span><span class="hljs-variable constant_">character_set_name</span></span><span>`** 来检测并统一文字セット,是保障系统稳定性の重要一环。
</span><span><span class="hljs-comment">## 1. `mysqli::character_set_name` の作用 </span></span><span>
`mysqli::</span><span><span class="hljs-title function_ invoke__">character_set_name</span></span><span>()` 方法用于返回当前接続する所使用の文字セット名称。它不会改变文字セット,チェックポイントを提供するだけです。それによって,我们可以存在する运行时确认数据库接続するの文字セット是否符合预期。
例:
```php
</span><span><span class="hljs-variable">$mysqli</span></span><span> = </span><span><span class="hljs-keyword">new</span></span><span> </span><span><span class="hljs-title function_ invoke__">mysqli</span></span><span>(</span><span><span class="hljs-string">"localhost"</span></span><span>, </span><span><span class="hljs-string">"user"</span></span><span>, </span><span><span class="hljs-string">"password"</span></span><span>, </span><span><span class="hljs-string">"dbname"</span></span><span>);
</span><span><span class="hljs-keyword">echo</span></span><span> </span><span><span class="hljs-variable">$mysqli</span></span><span>-></span><span><span class="hljs-title function_ invoke__">character_set_name</span></span><span>(); </span><span><span class="hljs-comment">// 例えば:utf8mb4</span></span><span>
</span></span>
実際のプロジェクトでは、一般的な問題は次のとおりです。
データベースAはUTF8MB4を使用し、データベースBはLATIN1にデフォルトです。
文字セットは、挿入時に明示的に指定されていないため、クロスストアデータに文字化けされたコードが得られます。
異なる接続の混合文字セット、比較と並べ替えの例外をスローします。
これらの隠された危険は、各接続が確立された直後に文字セットをチェックすることで回避できます。
接続時に文字セットを指定します
<span><span><span class="hljs-variable">$mysqli</span></span><span> = </span><span><span class="hljs-keyword">new</span></span><span> </span><span><span class="hljs-title function_ invoke__">mysqli</span></span><span>(</span><span><span class="hljs-string">"localhost"</span></span><span>, </span><span><span class="hljs-string">"user"</span></span><span>, </span><span><span class="hljs-string">"password"</span></span><span>, </span><span><span class="hljs-string">"dbname"</span></span><span>);
</span><span><span class="hljs-variable">$mysqli</span></span><span>-></span><span><span class="hljs-title function_ invoke__">set_charset</span></span><span>(</span><span><span class="hljs-string">"utf8mb4"</span></span><span>);
</span></span>
これにより、接続が必要な文字セットを常に使用することが保証されます。
チェック中にcharacter_set_nameを使用して確認します
<span><span><span class="hljs-keyword">if</span></span><span> (</span><span><span class="hljs-variable">$mysqli</span></span><span>-></span><span><span class="hljs-title function_ invoke__">character_set_name</span></span><span>() !== </span><span><span class="hljs-string">"utf8mb4"</span></span><span>) {
</span><span><span class="hljs-variable">$mysqli</span></span><span>-></span><span><span class="hljs-title function_ invoke__">set_charset</span></span><span>(</span><span><span class="hljs-string">"utf8mb4"</span></span><span>);
}
</span></span>
これにより、サーバーの構成が異なる場合でも、アプリケーションレイヤーが統一されたままになります。
複数の接続の統一された検証
<span><span><span class="hljs-variable">$connections</span></span><span> = [</span><span><span class="hljs-variable">$mysqli1</span></span><span>, </span><span><span class="hljs-variable">$mysqli2</span></span><span>];
</span><span><span class="hljs-keyword">foreach</span></span><span> (</span><span><span class="hljs-variable">$connections</span></span><span> </span><span><span class="hljs-keyword">as</span></span><span> </span><span><span class="hljs-variable">$conn</span></span><span>) {
</span><span><span class="hljs-keyword">if</span></span><span> (</span><span><span class="hljs-variable">$conn</span></span><span>-></span><span><span class="hljs-title function_ invoke__">character_set_name</span></span><span>() !== </span><span><span class="hljs-string">"utf8mb4"</span></span><span>) {
</span><span><span class="hljs-variable">$conn</span></span><span>-></span><span><span class="hljs-title function_ invoke__">set_charset</span></span><span>(</span><span><span class="hljs-string">"utf8mb4"</span></span><span>);
}
}
</span></span>
FORCINEデータベースサーバーのデフォルト設定に依存するのではなく、文字セット:接続の直後にset_charsetを呼び出します。
監視とロギング:開発環境またはテスト環境では、環境が一貫していることを確認するために、 character_set_nameの返品値を介してログを実行できます。
チーム契約:多干渉プロジェクトでは、潜在的な問題を軽減するために、統一された文字セット標準が明確に合意されています(通常は推奨されるUTF8MB4 )。
複数のデータベース接続シナリオでは、 MySqli :: Character_set_nameは、現在接続されている文字セットを確認するための便利な方法を提供します。 set_charsetの使用と併せて、クロスライブラリ操作における文字の一貫性を効果的に確保することができ、それにより、コードと互換性の問題を避けることができます。これは、マルチストアシステムでは無視できない詳細であり、データの精度とアプリケーションの安定性を確保するための重要なステップでもあります。
<span></span>
関連タグ:
mysqli