目次
返信内容:
ホームページ バックエンド開発 PHPチュートリアル javascript - データベース テーブルの特定のフィールドのデフォルトを Null、''、または空の文字列に設定する方が良いですか?携帯電話では空のまま返したいだけ

javascript - データベース テーブルの特定のフィールドのデフォルトを Null、''、または空の文字列に設定する方が良いですか?携帯電話では空のまま返したいだけ

Aug 31, 2016 am 08:54 AM
c java javascript node.js php

データベースの特定のフィールドが Null に設定されている場合、モバイル端末はデフォルトで Null を返します。モバイル端末に null を返してもらいたい場合は、判断する必要があります。
1. 携帯電話を何も判断せずに空に戻したい場合、テーブルフィールドのデフォルトをどのように設定すればよいですか?
2. テーブルフィールドのデフォルトを Null、""、または空の文字列に設定する方がよいでしょうか?それらは違うのでしょうか?

返信内容:

データベースの特定のフィールドが Null に設定されている場合、モバイル端末はデフォルトで Null を返します。モバイル端末に null を返してもらいたい場合は、判断する必要があります。
1. 携帯電話を何も判断せずに空に戻したい場合、テーブルフィールドのデフォルトをどのように設定すればよいですか?
2. テーブルフィールドのデフォルトを Null、""、または空の文字列に設定する方がよいでしょうか?それらは違うのでしょうか?

1: NULL 値 ('') はスペースを占有しません。
2: MySQL の NULL は実際にスペースを占有します。公式文書の説明:
「NULL 列には、その値が NULL かどうかを記録するために行に追加のスペースが必要です。MyISAM テーブルの場合、各 NULL 列は 1 ビット余分に必要となり、最も近いバイトに切り上げられます。そのため、お勧めできません。」 MySQL でテーブルを設計するときはデフォルトの NULL を使用してください
string 型はデフォルトの '' int 型でデフォルトの 0 にすることができます
投稿者がフィールドが空かどうかを確認したい場合は、php を使用して処理してください

SQL: NULL 値とデフォルト値の使用

デフォルト: NULL を使用するのは良いことですか?
MySQL でテキストおよび整数フィールドのデフォルト値としてデフォルト値なし、NULL、または 0 を使用するのは良いことですか?
まずは3つあげます

あまり違いはなく、どれでも大丈夫です、特にメリットもデメリットもありません。

stackoverflow上关于该问题的讨论吧,其实我个人感觉是使用默认值还是NULL携帯電話とのインターフェースは問題を返します。これは通常

を通じて行われます。 restful接口来交换数据的,其它语言我不是很清楚,但是在Java中实现返回值过滤或者默认值转换是非常easy的。参考setPropertyInclusion

これは「ハイパフォーマンス MySQL」で述べられていることです:

NULL を避けるようにしてください

通常、NULL 値を格納する必要がない限り、カラムを NOT NULL として指定するのが最善です。mysql テーブルの定義時にカラムが NOT NULL として指定されていない場合は、デフォルトで NULL が許可されます。

クエリに NULL になる可能性のあるカラムが含まれている場合、MySQL の最適化はより困難になります。 NULL になる可能性のある列により、インデックス、インデックス統計、値の比較がより複雑になるためです。

NULL にできる列はより多くのストレージ領域を使用し、MYSQL での特別な処理が必要になります。

NULL 可能な列にインデックスが付けられると、各インデックス レコードに追加のバイトが必要になり、MyISAM では固定サイズのインデックス (整数列が 1 つだけあるインデックスなど) が可変サイズのインデックスになる可能性もあります。

一般に、NULL 可能な列を NOT NULL に変更することによってもたらされるパフォーマンスの向上は比較的小さいため、問題が発生すると判断されない限り、チューニング時に最初にこの状況を変更する必要はありません。

ただし、列にインデックスを構築する予定がある場合は、列が NULL になるように設計しないようにする必要があります。もちろん例外もあります。たとえば、InnoDB は NULL 値を格納するために別のビットを使用します。これにより、スパース データに対して優れたスペース効率が得られます。これは MyISAM には適用されません。

(スパースデータ: 多くの値が NULL であり、いくつかの値が NULL ではないことを指します)

個人的には、主に null の配置に依存すると思います。配置が発生してはいけない異常なエラーである場合は、null に設定することをお勧めします。配置が正常で起こり得る状況である場合は、null を設定することをお勧めします。それを「」にします。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 Apr 05, 2025 am 12:04 AM

JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

母音を文字列にカウントするPHPプログラム 母音を文字列にカウントするPHPプログラム Feb 07, 2025 pm 12:12 PM

文字列は、文字、数字、シンボルを含む一連の文字です。このチュートリアルでは、さまざまな方法を使用してPHPの特定の文字列内の母音の数を計算する方法を学びます。英語の母音は、a、e、i、o、u、そしてそれらは大文字または小文字である可能性があります。 母音とは何ですか? 母音は、特定の発音を表すアルファベットのある文字です。大文字と小文字など、英語には5つの母音があります。 a、e、i、o、u 例1 入力:string = "tutorialspoint" 出力:6 説明する 文字列「TutorialSpoint」の母音は、u、o、i、a、o、iです。合計で6元があります

PHPでの後期静的結合を説明します(静的::)。 PHPでの後期静的結合を説明します(静的::)。 Apr 03, 2025 am 12:04 AM

静的結合(静的::) PHPで後期静的結合(LSB)を実装し、クラスを定義するのではなく、静的コンテキストで呼び出しクラスを参照できるようにします。 1)解析プロセスは実行時に実行されます。2)継承関係のコールクラスを検索します。3)パフォーマンスオーバーヘッドをもたらす可能性があります。

Java 8 Stream Foreachから休憩または戻ってきますか? Java 8 Stream Foreachから休憩または戻ってきますか? Feb 07, 2025 pm 12:09 PM

Java 8は、Stream APIを導入し、データ収集を処理する強力で表現力のある方法を提供します。ただし、ストリームを使用する際の一般的な質問は次のとおりです。 従来のループにより、早期の中断やリターンが可能になりますが、StreamのForeachメソッドはこの方法を直接サポートしていません。この記事では、理由を説明し、ストリーム処理システムに早期終了を実装するための代替方法を調査します。 さらに読み取り:JavaストリームAPIの改善 ストリームを理解してください Foreachメソッドは、ストリーム内の各要素で1つの操作を実行する端末操作です。その設計意図はです

PHPマジックメソッド(__construct、__destruct、__call、__get、__setなど)とは何ですか? PHPマジックメソッド(__construct、__destruct、__call、__get、__setなど)とは何ですか? Apr 03, 2025 am 12:03 AM

PHPの魔法の方法は何ですか? PHPの魔法の方法には次のものが含まれます。1。\ _ \ _コンストラクト、オブジェクトの初期化に使用されます。 2。\ _ \ _リソースのクリーンアップに使用される破壊。 3。\ _ \ _呼び出し、存在しないメソッド呼び出しを処理します。 4。\ _ \ _ get、dynamic属性アクセスを実装します。 5。\ _ \ _セット、動的属性設定を実装します。これらの方法は、特定の状況で自動的に呼び出され、コードの柔軟性と効率を向上させます。

PHPとPython:2つの一般的なプログラミング言語を比較します PHPとPython:2つの一般的なプログラミング言語を比較します Apr 14, 2025 am 12:13 AM

PHPとPythonにはそれぞれ独自の利点があり、プロジェクトの要件に従って選択します。 1.PHPは、特にWebサイトの迅速な開発とメンテナンスに適しています。 2。Pythonは、データサイエンス、機械学習、人工知能に適しており、簡潔な構文を備えており、初心者に適しています。

一致式(PHP 8)とそれがスイッチとどのように異なるかを説明します。 一致式(PHP 8)とそれがスイッチとどのように異なるかを説明します。 Apr 06, 2025 am 12:03 AM

PHP8では、一致式は、式の値に基づいて異なる結果を返す新しい制御構造です。 1)Switchステートメントに似ていますが、実行ステートメントブロックの代わりに値を返します。 2)一致式の式は厳密に比較され、セキュリティが向上します。 3)スイッチステートメントの脱落の可能性を回避し、コードのシンプルさと読みやすさを向上させます。

クロスサイトリクエストフォーファリー(CSRF)とは何ですか?また、PHPにCSRF保護をどのように実装しますか? クロスサイトリクエストフォーファリー(CSRF)とは何ですか?また、PHPにCSRF保護をどのように実装しますか? Apr 07, 2025 am 12:02 AM

PHPでは、予測不可能なトークンを使用して、CSRF攻撃を効果的に防ぐことができます。特定の方法には次のものが含まれます。1。フォームのCSRFトークンを生成および埋め込みます。 2.リクエストを処理するときにトークンの有効性を確認します。

See all articles