您好,登錄后才能下訂單哦!
(1)前言
使用了VS好多年,一直認(rèn)為制作報(bào)表是件很頭痛的事,不是自己沒(méi)有研究過(guò),但說(shuō)真的的確是很頭痛的事,尤其是C#下面的各種數(shù)據(jù)綁定,網(wǎng)上蠟人張的BLOG對(duì)RDLC就有很透徹的詳細(xì)說(shuō)明,我看了半天,就給那些報(bào)表結(jié)構(gòu)回路搞得莫名其妙,大師級(jí)別的人果然功力與我不一樣。因?yàn)轫?xiàng)目的需要,這兩天回爐一下自己從前的報(bào)表知識(shí),順便寫篇東西,好讓后來(lái)者別多太多像我一般的無(wú)謂腦力跟體力勞動(dòng)。
本人是位明顯的實(shí)用主義者,程序開發(fā)有太多的理論,量你一輩子的時(shí)間也絕對(duì)不可能全部了解清楚的,可當(dāng)你實(shí)際操作過(guò)一個(gè)工程的話,有些理論或許會(huì)不言而喻,很多專家都說(shuō),RDLC是很容易上手的,個(gè)人實(shí)踐證明,確實(shí)不難——只要你能硬著頭皮撐過(guò)我這篇入門級(jí)別的教程就好了,進(jìn)階的時(shí)候就真別問(wèn)我,我也是菜鳥。
(2)自定義數(shù)據(jù)集(DataSet)
網(wǎng)上挺多關(guān)于RDLC的例子其實(shí)都用了Northwind的那個(gè)例子,個(gè)人認(rèn)為,只是報(bào)表練練手就要?jiǎng)佑脭?shù)據(jù)庫(kù)好樣的龐然大物顯得有點(diǎn)過(guò)份,所以在本教程里我寧愿選擇自定義的數(shù)據(jù),代碼填充數(shù)據(jù)的內(nèi)容,作為一個(gè)簡(jiǎn)單的教程而言,單獨(dú)的示例工程就能運(yùn)行很重要,而且,不管是自定義的數(shù)據(jù)集還是取自SQLServer的數(shù)據(jù)集,在實(shí)際報(bào)表操作上沒(méi)什么差別,個(gè)人認(rèn)為自定義的數(shù)據(jù)集更靈活一點(diǎn)。
DataSet在VS上面的昵稱是“數(shù)據(jù)集”,可能探討過(guò)數(shù)據(jù)庫(kù)的童鞋對(duì)這個(gè)的理解得比我要多,我的理解是比較像圖形化的Struct集合體,可以更方便更靈活創(chuàng)建你所需要的數(shù)據(jù)結(jié)構(gòu)體,接下來(lái)就依照這樣定義好的結(jié)構(gòu)生成一個(gè)實(shí)例(myDataSet),再填充你獲得的數(shù)據(jù),一但你的報(bào)表跟實(shí)例作了綁定,那樣數(shù)據(jù)呈現(xiàn)就不需要我們多想了,微軟會(huì)自動(dòng)幫你做好的——這便是RDLC的整個(gè)開發(fā)思路而已,內(nèi)容不多。
下面是實(shí)操部分,我的開發(fā)環(huán)境是VS2012,好像以前用VS2008也是差不多的樣子。
1)新建一個(gè)VS2012的WinFrom工程項(xiàng)目,我的工程命名是“RdlcTest”;
2)在解決方案資源管理器中,右鍵工程,“添加”--“新建項(xiàng)”,選擇“數(shù)據(jù)集(DataSet)”,工程便增加了一個(gè)MyDataSet.xsd的項(xiàng),這個(gè)就是你自己定義的數(shù)據(jù)集啦;
3)雙擊MyDataSet.xsd,在圖形界面下新建你自己的數(shù)據(jù)結(jié)構(gòu)體,以下是我自己的例子,數(shù)據(jù)類型全部是String(右鍵打開列的屬性可以設(shè)置),有什么意義你就自己猜吧;
(2)新建報(bào)表及關(guān)聯(lián)數(shù)據(jù)集
1)在工程中添加一張報(bào)表(Report1.rdlc),我這里沒(méi)用“報(bào)表向?qū)А保陆ê煤箅p擊打開,你會(huì)看到一個(gè)報(bào)表設(shè)計(jì)頁(yè)面跟一個(gè)“報(bào)表數(shù)據(jù)”的窗口(話說(shuō)VS2012查找窗口還是相當(dāng)?shù)姆奖愕模?,在“?bào)表窗口”里添加一個(gè)數(shù)據(jù)集,你會(huì)看到下面這個(gè)對(duì)話框,選好剛剛建好的DataSet后,點(diǎn)確定即可。
2)添加報(bào)表數(shù)據(jù)集后的“報(bào)表數(shù)據(jù)”窗體是這樣一副模樣:
3)在報(bào)表設(shè)計(jì)窗口新建一個(gè)表,我們一條數(shù)據(jù)是7條個(gè)變量,就建一個(gè)七列的表(添加列的操作不需要詳解了吧),然后用鼠標(biāo)將“報(bào)表數(shù)據(jù)”里的DataSet1下的項(xiàng)逐個(gè)拖到表頭里去,會(huì)有下面的效果。
4)雖然新建好了表跟添加數(shù)據(jù)集,但現(xiàn)在因?yàn)檫€沒(méi)填充數(shù)據(jù),所以也不可能有東西出來(lái),何況你報(bào)表的容器還沒(méi)有弄好呢是吧?;仡櫼幌律厦娴牟襟E,我們姑且可以這么理清一下思路:一張報(bào)表(RDLC)、一個(gè)與報(bào)表關(guān)聯(lián)的數(shù)據(jù)集(DataSet)、N多數(shù)據(jù)的容器(表或文本框)構(gòu)成一張報(bào)表的全部元素,ReportView只是用來(lái)裝報(bào)表的容器而已。
(3)添加ReportViewer及關(guān)聯(lián)報(bào)表
1)打開你工程的MainForm的設(shè)計(jì)窗體,從“工具箱”中將“ReportViewer”拖到你的MainForm里去,當(dāng)你選擇ReportViewer時(shí),其右上角有個(gè)小三角形,點(diǎn)擊一下,可以看到很多選項(xiàng):
2)第一項(xiàng)選擇報(bào)表,當(dāng)然選剛剛你添加的“Report1.rdlc”,意思就是這個(gè)ReportViewer只顯示Report1.rdlc這張表;第二項(xiàng)選擇數(shù)據(jù)源,這里需要點(diǎn)思考,如下圖所示,報(bào)表數(shù)據(jù)源“DataSet1”是剛剛在“報(bào)表數(shù)據(jù)”窗口添加的一個(gè)數(shù)據(jù)集,而數(shù)據(jù)源實(shí)例又是什么呢?我選了項(xiàng)目里的MyDataSet--TestRecord,于是在這個(gè)MainForm的窗體下面會(huì)自動(dòng)生成一個(gè)myDataSet的數(shù)據(jù)集實(shí)例及testRecordBindingSource的綁定實(shí)例(同參考下圖),我的想法是“DataSet1”像個(gè)接口,“myDataSet”則是已經(jīng)實(shí)例化的變量,類似吧?至于“父容器??俊钡倪x項(xiàng),個(gè)人建議還是選了吧,好看一點(diǎn)。
3)假如你myDataSet里面已經(jīng)有內(nèi)容的話,你可以生成看到以下的這副樣子:
4)如何填充myDataSet的數(shù)據(jù),參見(jiàn)下面MainForm的窗體代碼,代碼應(yīng)該是不難理解的,重要的是我想數(shù)據(jù)多樣化一點(diǎn),方便進(jìn)行下一步的報(bào)表呈現(xiàn)講解,示例工程我放到51CTO下載里了,編譯環(huán)境是VS2012,下載地址是http://down.51cto.com/data/898719,下面博文的上傳機(jī)制貌似有問(wèn)題,有興趣的朋友可以隨便看看,高手莫拍。
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms; namespace RdlcTest { public partial class MainFrom : Form { public MainFrom() { InitializeComponent(); } /// <summary> /// 加載窗體 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> private void Form1_Load(object sender, EventArgs e) { //更新數(shù)據(jù)集的內(nèi)容 this.UpdateDataSet(); //刷新報(bào)表 this.reportViewer1.RefreshReport(); } /// <summary> /// 為myDataSet手動(dòng)添加數(shù)據(jù) /// </summary> private void UpdateDataSet() { for (int i = 0; i < 5; i++) { string id = DateTime.Now.ToString() + "-" + i.ToString("D2"); for (int j = 0; j < 4; j++) { this.myDataSet.TestRecord.AddTestRecordRow(id, "001", "shengqin", "Man", "Change Road", DateTime.Now, "describe : " + i.ToString("D3")); } } for (int j = 0; j < 4; j++) { this.myDataSet.TestRecord.AddTestRecordRow(DateTime.Now.ToString() + "-10", "002", "Joey", "Man", "Testing Speed", DateTime.Now, "describe : Joey's testing."); } for (int j = 0; j < 4; j++) { this.myDataSet.TestRecord.AddTestRecordRow(DateTime.Now.ToString() + "-11", "003", "Lily", "Woman", "Testing Speed", DateTime.Now, "describe : Lily's testing."); } for (int i = 20; i < 25; i++) { string id = DateTime.Now.ToString() + "-" + i.ToString("D2"); for (int j = 0; j < 4; j++) { this.myDataSet.TestRecord.AddTestRecordRow(id, "001", "shengqin", "Man", "Testing Speed", DateTime.Now, "describe : " + i.ToString("D3")); } } } } }
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。