テストテーブルを作成する-- ---------------------------- -- check_test のテーブル構造 -- ---------------------------- `check_test` が存在する場合はテーブルを削除します。 テーブル `check_test` を作成します ( `id` int(11) NOT NULL AUTO_INCREMENT, `current_price` varchar(10) NOT NULL, `price` varchar(10) NOT NULL, 主キー (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=9 デフォルト CHARSET=utf8; -- ---------------------------- -- check_test の記録 -- ---------------------------- `check_test` に値 ('1'、'12'、'14') を挿入します。 `check_test` に値 ('2'、'22'、'33') を挿入します。 `check_test` に値 ('3'、'15'、'8') を挿入します。 `check_test` に値 ('4', '9', '7') を挿入します。 `check_test` に値 ('5'、'12'、'12.9') を挿入します。 次の SQL を実行します。 -- current_price が price より小さいレコードを検索します。select * from check_test where current_price<price; check_test から (current_price+0)<(price+0) となる * を選択します。 -- current_price が price より大きいレコードを検索します。select * from check_test where current_price>price; check_test から (current_price+0)>(price+0) となる * を選択します。 結果は次のとおりです。 結果 1では、 15>8 は条件を満たしていませんが見つかります。一方、結果 3 では、 15>8 は条件を満たしていますが見つからないことがわかります。 これはなぜでしょうか?文字列型の数値の比較は、最初の桁から始まり、文字コード内の対応する値を比較します。等しい場合は、2 番目の桁の比較を続けます。等しくない場合は、大きい方の値が比較されます。数字に対応するASCIIコード値は次のとおりです。 例えば:
これは、JavaScript を使用してコードで確認できます。 var 現在の価格 = "12"; var 価格 = "14"; console.log(current_price < price); // true var 現在の価格 = "15"; var 価格 = "8"; console.log(current_price < price); // true そのため、比較する必要がある可能性のある数値は、varchar 型に設定しないでください。ただし、varchar 型に設定されている場合、比較する場合は、比較用に数値型に変換し、SQL でフィールドに 0 を追加します。 プログラミング言語の場合は、対応する関数を介して変換する必要があり、JavaScript のように 0 を追加して直接変換することはできません。 var 現在の価格 = "12"; var 価格 = "14"; console.log(parseInt(current_price) < parseInt(price)); // true var 現在の価格 = "15"; var 価格 = "8"; console.log(parseInt(current_price) < parseInt(price)); // false 注: 文字に対応する 10 進数値はエンコードに関連していますが、ASCII コードとは互換性があります。 参考リンク:文字列型の数値の比較 VARCHAR型文字列の比較 varchar型の数値のサイズの比較 これで、MySQL データベースの varchar 数値のサイズを比較する方法についての記事は終了です。MySQL varchar 数値のサイズの比較の詳細については、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: 画像をハイパーリンクとして使用したときに表示される青いボックスを削除する方法
この記事では、Gobangゲームを実装するためのキャンバスの具体的なコードを参考までに共有します。具...
Win10システムにMySQL8.0.20をローカルにインストールし、個人的にテストして利用可能であ...
この記事では、シャトルボックス機能を実現するためのjQueryの具体的なコードを参考までに紹介します...
関連記事:初心者が学ぶ HTML タグ (1)初心者は、いくつかの HTML タグを理解することで ...
目次序文1. 何ですか2. Node.jsでEventEmitterを使用する方法3. 実施プロセス...
この記事では、jsネイティブカルーセルプラグインの具体的なコードを参考までに共有します。具体的な内容...
縦型テーブル垂直テーブル分割とは、多数の列を持つテーブルを複数のテーブルに分割することを意味します。...
目次1. 双方向データバインディングとは1. データの双方向バインディングを実装する必要があるのはな...
多くの場合、画像をコンテナのサイズに合わせて調整する必要があります。 1. imgタグ方式幅と高さを...
目次1. プロトタイプの関係2. プロトタイプチェーン3. 結論序文:前回の記事では、JavaScr...
Tomcat7.0は仮想ディレクトリを設定します(1)現在、当社のウェブサイトはデフォルトのディレク...
はじめに: Web ページを作成するときに、画像をアップロードする必要がある場合がよくあります。画像...
目次アルゴリズム戦略単一ノードの差分配列ノードの差分キー値の使用要件アルゴリズム戦略React の調...
世界で最も有名なウェブサイトのロゴデザインにはどんなフォントが使われているかご存知ですか?これらのフ...
CSS3はクールな3D回転パースペクティブを実現します3D アニメーション効果はますます人気が高まっ...