日期:2014-05-17  浏览次数:20570 次

用水晶报表打印datagridview中的内容
打印按钮的代码如下,但是处理完后crystalReportViewer的对象打印预览只是一片空白,ds.table[0]显示没有数据,不知为何数据获取不了,请问如何解决呢
C# code

private void button1_Click_1(object sender, EventArgs e)
        {
            Form_ClystylePrint frm_print = new Form_ClystylePrint();

            MyData mydata = new MyData();
            SqlConnection cn = mydata.getConn();
            SqlCommand cmd = new SqlCommand();
            cmd.Connection = cn;
           

            cn.Open();
            cmd.CommandText = "select examiner 考官,car_shool 驾校,car 车牌号,car_type 车型,students_num 预约人数,table_maker 制表人 from Arrange_Table where exam_date = getdate()";
            
            SqlDataAdapter sda = new SqlDataAdapter(cmd.CommandText, cn);
            DataSet ds = new DataSet();
        
            sda.Fill(ds);
            

            dataGridView1.DataSource = ds.Tables[0];
           

            CrystalReport1 rpt1 = new CrystalReport1();
            rpt1.Load(Application.StartupPath + "CrystalReport1.rpt");
            rpt1.SetDataSource( ds.Tables[0]);//设置报表页面数据源
            
          
            frm_print.crystalReportViewer1.ReportSource = rpt1;
            cn.Close();
            cmd.Dispose();

            frm_print.Show();
        }





------解决方案--------------------
没做技术了,偶尔来CSDN来看看。
之前用的是水晶报表10或11,和你实现的不一样,不过我想再怎么样你也得在报表文件里面绑定数据库字段才行吧,你GRIDVIEW里面查出来又如何?它和报表没联系,即使你查出来有数据,但是你也必须要给报表绑定要显示的字段才对。