![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?8acaa2e)
開発環境
XP Home Edtion
Microsoft Visual C++ 2008 Express Edition
Microsoft SQL Server 2003 Express Edition
SQL文で1から5までのNoIDを取得してそれをダイアログのテキストボックスIDC_XS1からIDC_XS5の場所に入れようとしています。
int i=1;
String^ str;
char* dstChar2;
LPSTR dstLPSTR2;
SqlConnection^ sqlConn = gcnew SqlConnection("Data Source=.\\SQLEXPRESS;AttachDbFilename=C:\\SOUTUKEN\\test.mdf;Integrated Security=True;User Instance=True");
while(i<=5){
sqlConn->Open();
str= "SELECT * FROM Table1 WHERE NoID='"+i+"'";
SqlCommand^ sqlCmd = gcnew SqlCommand(str,sqlConn);
SqlDataReader^ exeReader = sqlCmd->ExecuteReader();
while(exeReader->Read()){str=exeReader["nyuryoku"]->ToString();
dstChar2 = (char*)(void*)Marshal::StringToHGlobalAnsi(str);
dstLPSTR2 = (LPCSTR)dstChar2;
#define IDC_XS IDC_XS##i //iの内容をIDC_XSに連結させたいのですがなかなかできないのです。
SetDlgItemText(hWnd,IDC_XS,dstLPSTR2);
i++;
}
sqlConn->Close();
どのようにしたらテキストボックス5つの中にSQL文の結果が入るのでしょうか。何卒よろしくおねがいします。
No.1ベストアンサー
- 回答日時:
こんにちは。
>>#define IDC_XS IDC_XS##i
流石に此れは無理です。
と言うのも、此れはテキスト置換なので、実行時にIDC_XS1, IDC_XS2...と言った連番IDを作ってくれる訳ではないのです。
なので、予めIDC_XS1, IDC_XS2...と書くしかありません。
簡単な話、配列の中に入れてしまえば良いのではないでしょうか。
//この様に書いたものを、
const int arrItemID[5] = {IDC_XS1, IDC_XS2, IDC_XS3, IDC_XS4, IDC_XS5};
//この様に指定する
::SetDlgItemText(hWnd, arrItemID[i], dstLPSTR2);
>SetDlgItemText(hWnd, arrItemID[i], dstLPSTR2);
これを書いたところ処理が停止してしまいテキストボックス内に入りません。
そしてリソースファイルには
IDM_ALL DIALOG DISCARDABLE 0, 0, 300, 300
STYLE DS_MODALFRAME | WS_CAPTION | WS_SYSMENU
FONT 16 , "MS Shell Dlg"
STYLE WS_CAPTION | WS_BORDER | WS_SYSMENU
CAPTION "データ一覧"
BEGIN
EDITTEXT IDC_XS1,0,10,50,14,ES_AUTOHSCROLL
EDITTEXT IDC_XS2,0,25,50,14,ES_AUTOHSCROLL
EDITTEXT IDC_XS3,0,40,50,14,ES_AUTOHSCROLL
EDITTEXT IDC_XS4,0,55,50,14,ES_AUTOHSCROLL
EDITTEXT IDC_XS5,0,70,50,14,ES_AUTOHSCROLL
END
というようにダイアログを設定しています。
リソースファイルに何か原因があるのでしょうか?
No.2
- 回答日時:
Windows フォーム アプリケーションであれば、
>char* dstChar2;
>LPSTR dstLPSTR2;
はあまり使わないほうがやりやすいです。
>SetDlgItemText(hWnd,IDC_XS,dstLPSTR2);
はなぜ、こちらを使っているのでしょうか?
TextBoxオブジェクトは使えないのでしょうか?
(しかも「マルチバイト文字セット」でビルド?無駄が多い気が。。。)
ちなみにTextBoxを配列にするには
http://hpcgi1.nifty.com/MADIA/Vcbbs/wwwlng.cgi?p …
を参考にしてみてください。
参考資料役に立ちました。
bluecampusさんとmachongolaさんのいわれていたことをしてやっとできました。どうもありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# c言語配列の結合についてです。 なぜうまくいかないのでしょうか。 #include <stdio.h 4 2022/05/30 22:42
- C言語・C++・C# C#テキストボックスの文字を配列にいれてその後表示する 4 2022/07/17 04:47
- C言語・C++・C# 宣言する関数の形が決まっている状態で、 str1とstr2の文字列をこの順に引っ付けてstrに保存し 2 2022/05/30 18:21
- C言語・C++・C# プログラミングの授業の課題です 1 2023/01/17 22:15
- C言語・C++・C# c言語 プログラムのエラー 1 2023/02/11 20:31
- Excel(エクセル) PHPプログラムをエクセルに張り付けると検索ボックスがでてくる! 3 2022/05/08 07:10
- C言語・C++・C# str[j++]の意味 2 2022/08/30 16:20
- SQL Server [SQLServer] テーブル名からカラム名を取得する 1 2022/08/23 21:20
- PHP PostgreSQLからCSV形式でエクスポートする際にカラム内の改行をとる方法 1 2023/02/22 10:05
- その他(プログラミング・Web制作) python質問 1 2023/08/14 11:54
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
C言語 配列の長さの上限
-
配列を使わずに、変数名を動的...
-
配列で格納したものをmsgboxで...
-
C# Listを使わずに2次元配列の...
-
【速いブラインドタッチ】手を...
-
ExcelVBAで質問です。離れた二...
-
C# 配列の変数宣言について。
-
市販のビンゴカードについて
-
C言語 配列の再初期化
-
テキストボックスに文字列を入れる
-
C言語の配列の入れ方について質...
-
MFC、ダイアログベースでのモー...
-
先頭アドレスとは何ですか?
-
VBでC言語のポインタみたい...
-
【VBS】 フォルダ直下のファイ...
-
画像処理
-
c言語でのヒストグラム作成用の...
-
ポインタの配列のコンマについて
-
C言語で特定列だけを抽出して配...
-
#N/Aを含む列の最小値の求め方
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
C言語 配列の長さの上限
-
配列を使わずに、変数名を動的...
-
先頭アドレスとは何ですか?
-
配列で格納したものをmsgboxで...
-
C# Listを使わずに2次元配列の...
-
C# 配列の変数宣言について。
-
テキストファイルから文字列を...
-
配列の参照渡しで型が一致しま...
-
ExcelVBAで質問です。離れた二...
-
unsigned char配列への入力の仕方
-
VBで構造体の配列を関数に渡す...
-
C++ vectorに配列をプッシュしたい
-
C言語で特定列だけを抽出して配...
-
複数の選択範囲の行番号を個別...
-
Excel、VBAのユーザーフォーム...
-
配列をEraseしてもメモリが開放...
-
配列を含む構造体の初期値について
-
【速いブラインドタッチ】手を...
-
Redimした動的配列はEraseする...
-
C言語 配列の再初期化
おすすめ情報