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

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

新規登録して質問してみよう
ただいま回答率
85.48%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Q&A

解決済

3回答

9702閲覧

Listへテーブルの行データを格納する

a0831t

総合スコア2

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

0グッド

1クリップ

投稿2020/08/24 15:00

Oracle19cから取得したデータを行単位にListに格納する方法について教えてください。
#テーブル
countryテーブル

Nocountry_namecapital_city
01日本東京
02アメリカワシントンD.C
03カナダオタワ
04イギリスロンドン

#現状
DBからcountryテーブルの各データを取得し、それぞれを別のListを作成し、カラム別の3つのリストに格納
「同じ要素の値」=「countryテーブルで同じ行にあるデータ」とみなして、countryテーブルの行データをすべて取得しています。

#実現したい結果
下記コードで各カラム用に作成したリストを1つにする。
for文の外で、格納したリストの結果を「No.01、国名:日本、首都:東京」のようなイメージでポップアップさせる。

#環境
VisualStudio

C#

1 2//各カラム用の配列 3List<string> countryNo = new List<string>(); 4List<string> countryName = new List<string>(); 5List<string> capitalCity = new List<string>(); 6 7for(int i = 0; i < country.Count; i++) 8{ 9countryNo.Add(country[i].No); 10countryName.Add(country[i].country_name); 11capitalCity.Add(country[i].capital_city); 12} 13 14//テーブルデータをメッセージとして表示する

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

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

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

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

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

退会済みユーザー

退会済みユーザー

2020/08/24 22:57

> Oracle19cから取得したデータを行単位にListに格納する方法について教えてください。 「取得した」と過去形になってますが、実際聞きたいことは、何らかの手段で SELECT クエリを投げて country テーブルからレコードを取得する所からどうしたらいいかということでは?
guest

回答3

0

ベストアンサー

質問へのコメント、

「取得した」と過去形になってますが、実際聞きたいことは、何らかの手段で SELECT クエリを投げて country テーブルからレコードを取得する所からどうしたらいいかということでは?

に返事がないですが、たぶんそういうことであろうと想像して・・・

以下のようなクラスを定義し、

public class Country { public string No { get; set; } public string Country_name { get; set; } public string Capital_city { get; set; } }

DB から ADO.NET と ODP.NET を利用してデータを取得して、List<Coontry> 型のオブジェクトを作成することをお勧めします。それが作成できれば、質問者さんのやりたいこと、

格納したリストの結果を「No.01、国名:日本、首都:東京」のようなイメージでポップアップさせる。

は容易にできると思います。

ADO.NET を使ったコード例は以下の記事の CreateOrderList メソッドを見てください。

異なるデータソースの結合と表示
http://surferonwww.info/BlogEngine/post/2017/11/26/how-to-join-and-show-the-records-from-different-data-sources.aspx

上のサンプルは SQL Server ですので SqlClient の SqlConnection, SqlCommand, SqlDataReader を使っていますが、 ODP.NET の OracleConnection, OracleCommand, OracleDataReader に変更すれば同等のことができるはずです。

投稿2020/08/25 03:29

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

a0831t

2020/08/25 13:21

確認が遅くなり申し訳ありません。 ご認識いただいている通りです。こちらの説明不足でした。 サンプルコードとURLありがとうございます。 参考にさせていただきます。
guest

0

下記コードで各カラム用に作成したリストを1つにする。

カラム別にListに取得して後で結合するくらいなら、DBのSELECT時にDataTableへ結果をまとめて取得した方がシンプルになると思います。

https://teratail.com/questions/269599
上記URLで私が回答しているのはMySQLの例ですが、Oracleなら MySqlXXX となっているオブジェクトをOracle用のものに置き換えれば、同じやり方で取得可能です。

投稿2020/08/25 00:04

編集2020/08/25 00:11
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

a0831t

2020/08/25 13:24

回答いただきありがとうございます。 こちらの手法についても別パターンとして参考にさせていただきます。
guest

0

C#

1var countryNo = new List<string> { "01", "02", "03", "04" }; 2var countryName = new List<string> { "日本", "アメリカ", "カナダ", "イギリス" }; 3var capitalCity = new List<string> { "東京", "ワシントンD.C.", "オタワ", "ロンドン" }; 4 5var countries = countryNo. 6 Zip(countryName, (no, name) => new {no, name}). 7 Zip(capitalCity, (x, city) => new { x.no, x.name, city}). 8 ToList(); 9 10foreach (var country in countries) { 11 Console.WriteLine($"No.{country.no}, 国名:{country.name}, 首都:{country.city}"); 12}

投稿2020/08/24 15:54

編集2020/08/24 23:18
Daregada

総合スコア11990

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

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

gentaro

2020/08/24 17:14

質問が「Listに格納する方法」なのでToList()ぐらいは付けるべきでは。
Daregada

2020/08/24 23:16

そうだった。
Zuishin

2020/08/24 23:42 編集

確かに手っ取り早く質問には答えてるけど。自分の仕事だとして実際こんなコード書きますか? データの取得先は Oracle DB なのに。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問