有効な MySQL 自動インクリメント値として 0 を強制する
SQL ファイルをスケル ファイルとしてインポートする場合、多くの場合、ユーザー ID などのフィールドの有効な自動インクリメント値として 0 の値が使用されます。ただし、デフォルトでは、MySQL は 0 を自動インクリメント フィールドの無効な値として扱います。
この問題を回避するために、MySQL は sql_mode 設定を提供します。 sql_mode を NO_AUTO_VALUE_ON_ZERO に設定すると、MySQL は INSERT/UPDATE ID 0 を有効な値として解釈するように指示され、代わりに次のシーケンス ID を挿入できなくなります。
この動作を強制するには、次のコマンドを使用できます。 :
SET [GLOBAL|SESSION] sql_mode='NO_AUTO_VALUE_ON_ZERO'
GLOBAL スコープは設定を今後のすべての接続に適用しますが、SESSION スコープは設定を現在のセッションに制限します。
sql_mode を NO_AUTO_VALUE_ON_ZERO に設定すると、auto に 0 を挿入できます。 -MySQL が代わりに次のシーケンス ID を挿入せずにフィールドを増分します。ただし、アプリケーションがこの動作を正しく処理するように設計されていない場合、この動作により潜在的な不一致が発生する可能性があることに注意することが重要です。
以上がMySQL の自動インクリメント フィールドに 0 を挿入するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。