もともと公開されていたURL
https://support.microsoft.com/ja-jp/topic/dbd90920-deeb-c549-d470-43a020594f33
現在は
必須プロパティ (Access)
に一部含まれている。(ちなみにまた変な誤訳になっていて、「必須プロパティ」とは「値要求プロパティ」、つまり「値要求設定」のこと。)
Access の Null 値と、長さ 0 の文字列の違いについて
概要
この資料では、Microsoft Accessで、値がない状態を示す2つの状態について、説明します。
詳細
フィールドに値がないもの (空白値) には、データが未入力のものや、Enter キーを押しただけの入力、半角および全角スペースが入力されているものなどがありますが、Access では、空白値を「Null 値」と「長さ 0 の文字列 (空文字列)」という 2 種類に識別しています。
これらは Access 上で区別される場合と、区別されない場合があります。
例 :
テーブルの値をコピー後貼り付けた場合
コピー元の値に関わらず、後述のテーブルにあらかじめ設定された動作に従い、空白値を挿入します。Where 句などで、空白値を取り出す場合
"Is Null" および "Not Like "*"" は、フィールドに値がないもの (空白値) を抽出する時に使用する条件式です。 "Is Null" は フィールドに「Null 値」をもつものを検索し、"Not Like "*"" は、「長さ 0 の文字列 (空文字列)」を検索するという違う意味を持っていますが、抽出結果は同じです。- Null値とは
- 長さ 0 の文字列とは
- 長さ 0 の文字列を入力するには
- 値要求と空文字列の許可設定値の組み合わせから入力される値について
Null 値とは
Null 値とは、データが存在しないこと、またはデータが不定であることを示す値で、フィールドに入力したり、式およびクエリで使用する値です。 たとえば、空白値を抽出するために、抽出条件を "Is Null" とした場合は、空白で、かつ長さ 0 の文字列 (空文字列) も入力されていないものが抽出されます。長さ 0 の文字列とは
長さ 0 の文字列とは、文字を 1 つも含まない空文字列のことで、意図的にフィールドに値がないことを示します。 長さ 0 の文字列を入力するには、スペースを含めずにダブル クォーテーションを 2 つ ("") 入力します。 テーブルによっては、長さ 0 の文字列を入力できない場合がありますが、テーブルのフィールド プロパティで設定を変更することができます。 たとえば、空白値以外を抽出するために抽出条件を "Like "*"" とした場合、空白でも、0 バイトの文字列 ("") が入力されている場合は、データが抽出されます。 空白値を抽出するために抽出条件を "Not Like "*"" とした場合、空白でも、0 バイトの文字列 ("") が入力されている場合は、データは抽出されません。長さ 0 の文字列を入力するには
フィールドを空白のままにするときに、Null 値ではなく長さ 0 の文字列を入力する場合は、[値要求] プロパティおよび [空文字列の許可] プロパティの両方を [はい] にする必要があります。 [値要求] プロパティが [はい] の場合は、Null 値以外の値を入力する必要があります。 フィールドの [値要求] プロパティおよび [空文字列の許可] プロパティを [はい] にするには、以下の手順を実行します。-
テーブルをデザイン ビューで開きます。
[オブジェクト] の [テーブル] をクリックし、一覧から任意のテーブルをクリックします。次に、[デザイン] をクリックします。
ここでは例として、[商品] テーブルを選択します。/br> -
フィールドを選択します。
プロパティを変更するフィールドをクリックします。
ここでは例として、[備考] を選択します。 -
[値要求] および [空文字列の許可] プロパティの設定を変更します。
[標準] タブをクリックします。次に、[値要求] および [空文字列の許可] ボックスの一覧から [はい] をクリックします。 - テーブルを閉じます。 [閉じる] ボタンをクリックします。
-
変更内容を保存します。
"テーブルの変更を保存しますか?" というメッセージが表示されたら、[はい] をクリックします。
ダブルクォーテーションを 2 つ ("") 入力することによって、長さ 0 の文字列をテーブルに格納できるようになります。
値要求と空文字列の許可設定値の組み合わせから入力される値について
値要求と空文字列の許可設定値の組み合わせから入力される値は、以下のとおりです。
値要求 | 空文字列の許可 | 操作 | 入力される値 |
---|---|---|---|
いいえ | いいえ |
Enter キーを押す。 Space キーを押す。 長さ 0 の文字列を入力する。 |
Null Null 入力不可 |
いいえ | はい |
Enter キーを押す。 Space キーを押す。 長さ 0 の文字列を入力する。 |
Null Null 長さ0の文字列 |
はい | いいえ |
Enter キーを押す。 Space キーを押す。 長さ 0 の文字列を入力する。 |
入力不可 入力不可 入力不可 |
はい | はい |
Enter キーを押す。 Space キーを押す。 長さ 0 の文字列を入力する。 |
入力不可 長さ0の文字列 長さ0の文字列 |
関連情報
881379 データを抽出するには - クエリの概要
882979 クエリでフィールドに値がないもの (Null 値) を抽出するには - クエリの抽出条件の例
883246 クエリで任意の文字列が含まれるフィールドを抽出するには - クエリの抽出条件の例
294954 [ACC2002] パラメータ クエリで LIKE 演算子を使用する方法 - クエリの抽出条件の例
411174 [ACC2002] 空白値を含むテーブルを Excel 形式としてエクスポートした場合、空白セルとして認識されない
さらにAC2013では以下のような三部作になっている。
AC2013 クエリの抽出条件 - 第 1 部: 具体的に指定する
AC2013 クエリの抽出条件 - 第 2 部: LIKE 演算子とは
AC2013 クエリの抽出条件 - 第 3 部: パラメーターを使って入力を求める
Exporting a table from Access to Excel with Null Values (want the field Numeric)
Excel cells from Access export look empty but are not (=isblank=FALSE) - Stack Overflow
Access2007で同様の現象が起きている
この場合 書式設定とレイアウトを保持したままデータをエクスポートするのチェックボックスをオフとする