昨夜、MySQL データベースにデータセットを挿入したときにエラーが発生しました。データベースは容赦なくエラーを報告しました: 分析 つまり、sql_mode は、MySQL がサポートする SQL 構文やデータ検証などを定義します。 。 現在のデータベースで使用されている sql_mode を表示する方法: mysql> @@sql_mode を選択します。 私のデータベースの現在のスキーマは次のとおりです。 MySQL サーバーはさまざまな SQL モードで動作し、さまざまなクライアントに対してさまざまな方法でこれらのモードを適用できます。これにより、アプリケーションはニーズに合わせてサーバー操作をカスタマイズできます。このようなモードは、MySQL がサポートする必要がある SQL 構文と、データに対して実行する必要がある検証チェックを定義します。これにより、さまざまな環境で他のデータベース サーバーと共に MySQL を簡単に使用できるようになります。 MySQL 4.1 以降では、起動後に sql_mode 共通値 完全グループ化のみ GROUP BY 集計操作の場合、SELECT、HAVING、または ORDER BY 句の列が GROUP BY に表示されない場合は、SQL は無効です。 不正な SQL ステートメントの場合、実行時に次のエラーが報告されます。 ゼロ以外 この値は、自動インクリメント列への挿入に影響します。デフォルトでは、0 または NULL を挿入すると、次の自動インクリメント値が生成されます。このオプションは、ユーザーが値 0 を挿入し、列が自動増分されている場合に便利です。 STRICT_TRANS_TABLES このモードでは、トランザクション テーブルに値を挿入できない場合、現在の操作が中断され、非トランザクション テーブルには制限が課されません。 日付にゼロがない 厳密モードでは、月または日の部分が 0 の日付は受け入れられません。 IGNORE オプションを使用すると、同様の日付に「0000-00-00」が挿入されます。非厳密モードでは、日付は受け入れられますが、警告が生成されます。 日付なし 厳密モードでは、「0000-00-00」を有効な日付として考慮しません。 IGNORE オプションを使用すると、ゼロの日付を挿入することもできます。非厳密モードでは、日付は受け入れられますが、警告が生成されます。 ゼロ除算エラー INSERT または UPDATE 中にデータがゼロで除算されると、警告ではなくエラーが生成されます。このモードが指定されていない場合、値がゼロで除算されると、MySQL は NULL を返します。 いいえ GRANT が空のパスワードを持つユーザーを作成しないようにする エンジン代替なし 必要なストレージ エンジンが無効になっているか、コンパイルされていない場合は、エラーがスローされます。この値が設定されていない場合は、代わりにデフォルトのストレージ エンジンが使用され、例外がスローされます。 パイプASCONCAT 「||」をOR演算子ではなく文字列連結演算子として扱います。これはOracleデータベースと同じで、文字列連結関数Concatに似ています。 ANSI_QUOTES ANSI_QUOTES が有効になっている場合、二重引用符は識別子として解釈されるため、文字列を引用符で囲むことはできません。 MySQL 5.0 以降のバージョンでは、ANSI、TRADITIONAL、STRICT_TRANS_TABLES の 3 つの sql_mode モードがサポートされています。 1. ANSI モード: ルーズ モード。標準 SQL との一貫性を高めるために構文と動作を変更します。挿入されたデータを確認します。定義されたタイプまたは長さに準拠していない場合は、保存する前にデータ型を調整するか切り捨て、警告を発します。この記事の冒頭で述べたエラーについては、まず sql_mode を ANSI モードに設定してデータを挿入できるようにし、除数が 0 であるフィールド値についてはデータベースによって NULL 値に置き換えられます。 2. 伝統的モード: 厳密モード。MySQL データベースにデータを挿入するときに、誤ったデータが挿入されないように厳密なデータ検証が実行され、警告だけでなくエラーが報告されます。トランザクションに使用すると、トランザクションはロールバックされます。 注意: エラーが見つかった場合は、INSERT/UPDATE を直ちに中止してください。非トランザクション ストレージ エンジンを使用している場合、エラー発生前に行われたデータ変更は「ロールオーバー」されず、「部分的に実行された」更新となるため、これは望ましいことではありません。 3. STRICT_TRANS_TABLES モード: 厳密なモードでは、厳密なデータ検証が実行され、不正なデータは挿入できず、エラーが報告されます。指定された値をトランザクション テーブルに挿入できない場合、ステートメントは中止されます。非トランザクション テーブルの場合、値が単一行ステートメントまたは複数行ステートメントの行 1 に表示されると、ステートメントは破棄されます。 sql_modeの設定 現在の接続セッションの SQL モードを表示します。 mysql> @@session.sql_mode を選択します。 または環境変数から mysql> 「sql_mode」のような変数を表示します。 グローバル sql_mode 設定を表示します。 mysql> @@global.sql_mode を選択します。 グローバルに設定すると、有効にするには再接続する必要があります mysql> グローバル sql_mode を 'NO_AUTO_CREATE_USER、NO_ENGINE_SUBSTITUTION、NO_ZERO_DATE、NO_ZERO_IN_DATE' に設定します。 グローバルsql_modeの設定はMySQLを再起動しなくても有効になります。 設定ファイルの設定 sql_mode=NO_AUTO_CREATE_USER、NO_ENGINE_SUBSTITUTION、NO_ZERO_DATE、NO_ZERO_IN_DATE 設定ファイルを変更したら、MySQLサービスを再起動して変更を有効にします。 要約する 以上がこの記事の全内容です。この記事の内容が皆様の勉強や仕事に何らかの参考学習価値をもたらすことを願います。123WORDPRESS.COM をご愛顧いただき、誠にありがとうございます。これについてもっと知りたい場合は、次のリンクをご覧ください。 以下もご興味があるかもしれません:
|
>>: 10分でDockerを使ったマイクロサービスのデプロイ方法を学ぶ
目次序文1. Linux は yum ソースを変更します (MYSQL のインストールが遅い場合は試...
VMwareでcentos8サービスをインストールしてコピーすると、次の問題が発生します。 コピー前...
用語: 1. VM: 仮想マシンステップ: 1. Windows 10 に VirtualBox 6...
声明:この記事では、Web ページ制作技術を使用して問題を包括的に解決するという考え方を反映して、W...
目次tf-gpu をダウンロード取得したtf-gpuイメージに基づいて独自のイメージを構築するイメー...
マスタースレーブレプリケーションがなぜ必要なのでしょうか? 1. 複雑な業務システムでは、SQL 文...
目次イベントループmiscroTask (マイクロタスク) UI レンダリング (重要なポイント)次...
目次設定を追加json 構成レイヤー構成の表示論理層の構成位置追跡をオンにする録音を開始開始座標を決...
目次序文REDOログの生成REDOログ送信REDOログの保存と通知ユーザースレッドに通知要約する序文...
目次1. 解析する1.1 傍受のルール1.2 傍受プロセス部分1.3 パーサーの概要2. 最適化する...
コマンドを実行します: docker run --name centos8 -d centos /b...
適切に機能するテーブル プロパティ設定:コードをコピーコードは次のとおりです。 <テーブル セ...
多くのプログラマーは MySQL に精通していると思います。多くの人が count の使い方と、最適...
Dockerコンテナのインストール時に遭遇しやすい2つの問題1.ポートはすでに割り当てられています(...
この記事では、MySQL データベースの一般的な操作テクニックをまとめます。ご参考までに、詳細は以下...