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

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

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

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

Visual Studio 2012

Microsoft Visual Studio 2012は、Microsoftによる統合開発環境(IDE)であり、多種多様なプログラミング言語に対応しています。 Visual Studio 2010の次のバージョンです

Q&A

解決済

2回答

7443閲覧

1つ目のレコードしかReportViewerに表示できない

morinokuma0621

総合スコア81

C#

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

Visual Studio 2012

Microsoft Visual Studio 2012は、Microsoftによる統合開発環境(IDE)であり、多種多様なプログラミング言語に対応しています。 Visual Studio 2010の次のバージョンです

0グッド

0クリップ

投稿2018/05/29 08:35

編集2018/05/29 08:59

帳票印刷用のツールを作っています。印刷マスタ上にデータは50レコードほどあり、それを連続して印刷したいと思っています。下記のコードはどこかのサイトを参考にして、ほぼコピペで作りましたが、ReportViewer上に表示し、印刷するところまではできるようになりました。

しかし、SELECT結果で出てくる先頭のレコードしかReportViewerに表示できません。Fillの仕方が間違っているのではないかと思うのですが、どこをどうすれば良いのでしょうか。

C#

1 2string tSQL = "SELECT * FROM 印刷マスタ"; 3 4DataSet1 ds1 = new DataSet1(); 5reportViewer1.Reset(); 6reportViewer1.ProcessingMode = ProcessingMode.Local; 7reportViewer1.LocalReport.ReportPath = Environment.CurrentDirectory + @"../Report1.rdlc"; 8ReportDataSource rds = new ReportDataSource(); 9rds.Name = "DataSet1"; 10rds.Value = ds1.dt1; 11 12//ReportViewerに表示 13this.reportViewer1.LocalReport.DataSources.Add(rds); 14this.reportViewer1.RefreshReport(); 15 16//データセット作成 17SqlDataAdapter adapter = new SqlDataAdapter(tSQL, s.sCon); 18adapter.Fill(ds1.dt1);

追記:
rds.Value = ds1.dt1のdt1の中には、SELECT文の結果が正しく入っていることは確認しました。

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

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

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

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

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

guest

回答2

0

自己解決

答えがわかりました!
今回、単票印刷をしようとしていたわけですが、どうやらテキストボックスを配置しただけでは単票印刷とは認識されなかったようです。

レポートのデザイン画面で、ツールにある『テキストボックス』を直接配置していくのではなく、まず最初に『一覧』というグループボックスのようなものを配置し、その中にテキストボックスを並べていくのが正解だったようです。

加えて、その『一覧』のプロパティで『後に改ページを追加する』のチェックを入れることで、2ページ目からも体裁がずれることなく印刷できるようになりました。

それとこれはよくわからないのですが、『一覧』を配置したはずなのにプロパティのところでは『四角形』と名前が変わっていたりしました。一覧の中に四角形というツールがデフォルトで入るようになっているのかもしれませんが、よくわかりません。

投稿2018/05/30 07:56

morinokuma0621

総合スコア81

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

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

0

//ReportViewerに表示

this.reportViewer1.LocalReport.DataSources.Add(rds);
this.reportViewer1.RefreshReport();

すくなくともRefreshReport()は最後にしてください。
それで解決しなければRDLCのほうかもしれません。

投稿2018/05/29 09:46

hihijiji

総合スコア4150

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

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

morinokuma0621

2018/05/30 00:08

ご回答ありがとうございます。 RefreshReportを最後にしても変わりませんでした。 rdlcの方をいろいろ探ってみます。
morinokuma0621

2018/05/30 06:17

やはりどうやっても1レコード目しか出てきませんね……。 何か他に解決方法ご存知の方、いらっしゃいませんでしょうか。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問