質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Null

Nullとは、プログラミング言語やデータベースにおけるデータ表現の一種です。コンテキストによって"空"もしくは"長さ0の文字列"、”未知・不明”を意味します。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Q&A

解決済

2回答

687閲覧

SQL:無いレコードの連結

退会済みユーザー

退会済みユーザー

総合スコア0

Null

Nullとは、プログラミング言語やデータベースにおけるデータ表現の一種です。コンテキストによって"空"もしくは"長さ0の文字列"、”未知・不明”を意味します。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

0グッド

0クリップ

投稿2021/05/30 13:55

TABLE_A に名前(NAME)、TABLE_Bに点数(POINT)が書いてあって
UIDが3の人がPOINT出してなくてレコードがなかった場合。

TABLE_A

UIDNAME
1佐藤
2鈴木
3斎藤

TABLE_B

UIDPOINT
1100
290

SELECT UID, A.NAME, B.POINT FROM TABLE_A AS A NATURAL JOIN TABLE_B AS B

このSQLだと

UIDA.NAMEB.POINT
1佐藤100
2鈴木90

こうなってしまいます。
これを

UIDA.NAMEB.POINT
1佐藤100
2鈴木90
3斎藤NULL

とするにはどうしたらよいでしょうか?
LEFT OUTER JOINもなにかうまくいかなくて><

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2021/05/30 14:09

《うまくいかなくて><》全然わからないので、より具体的に説明してくださいね。
guest

回答2

0

ベストアンサー

LEFT OUTER JOINにはON句にリレーションを記載する必要があります。

SQL

1SELECT 2 A.UID, 3 A.NAME, 4 B.POINT 5FROM TABLE_A AS A 6LEFT OUTER JOIN TABLE_B AS B 7 ON A.UID = B.UID

このLEFT OUTER JOINが「なにかうまくいかなくて」という状況は、SQLの基礎知識および技量が圧倒的に足りていません。
初心者向けの書籍を購入して、基礎の基礎から勉強しなおしましょう。
Webで適当に検索して学習するスタイルではダメです。

投稿2021/05/30 14:13

hope_mucci

総合スコア4447

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2021/05/30 14:22

ごめんなさい。 NATURAL JOINのまま共通のUIDを、UIDとしてSELECT句にいれていて エラーになっていただけでした。 A.UIDとしたらうまくいきました(^^; 一年もSQL使ってないとわすれちゃいます・・・
guest

0

sql

1SELECT A.UID, A.NAME, B.POINT 2FROM TABLE_A AS A LEFT OUTER JOIN TABLE_B AS B ON A.UID = B.UID;

とか。
UIDが両テーブルで存在するので、テーブル名のエイリアスを付けるなどして明瞭化しないとダメ。

SQLのドキュメントを見られるようにブックマークしておくといいです。
とくに文法は何度も見る場面だと思いますので。

MySQL :: MySQL 5.6 リファレンスマニュアル
MySQL :: MySQL 5.6 リファレンスマニュアル :: 13.2.9.2 JOIN 構文

投稿2021/05/30 14:11

編集2021/05/30 14:24
退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問