C#水晶报表显示sqlserver2000储存的图片 C#水晶报表动态显示sqlserver储存的图片

首先在项目表中添加水晶报表要用的img表 DataTable1 img字段类型为System.Byte[] 切忌一定为System.Byte[] c#自认为System.Byte, 【】自己添加。在需要显示的地方写代码如下

GlassBbiaoDataSet.ImageDataTable tbl2 = new GlassBbiaoDataSet.ImageDataTable();

 private void fmReport_Load(object sender, EventArgs e)
        {
            string cmdText = "";
            SqlConnection conn = new SqlConnection();
            conn.ConnectionString = clsData.connStr;
            SqlCommand cmd = new SqlCommand("", conn);
            SqlDataReader rd;

            if (ddh != "")
            {
                cmdText = "select * from VIWp where 订单号='" + ddh + "'";
                cmd.CommandText = cmdText;
                try
                {
                    conn.Open();
                    rd = cmd.ExecuteReader();
                    gldst = new GlassBbiaoDataSet();
                    gldst.VIWp.Load(rd);
                    Cpt21.SetDataSource((DataTable)gldst.VIWp);//Cpt21是主报表
                    string sqlImage = "select imagea from Image where picid='" + ddh + "'";
                    SqlDataReader drd = null;
                    long maxLenth = 10000000;
                    Byte[] bytImage = new Byte[maxLenth];
                    long imgLenth;
                    GlassBbiaoDataSet.DataTable1DataTable dTable = new GlassBbiaoDataSet.DataTable1DataTable();
                    try
                    {
                        cmd.CommandText = sqlImage;
                        drd = cmd.ExecuteReader();
                        while (drd.Read())
                        {
                            drd.GetBytes(0, 0, bytImage, 0, (int)maxLenth);

                            GlassBbiaoDataSet.DataTable1Row drow = dTable.NewDataTable1Row();
                            drow.img = bytImage;
                            dTable.Rows.Add(drow);
                        }
                    }
                    catch { };
                   // picrep rpt = new picrep();
                   // rpt.SetDataSource((DataTable)dTable);

                        //tbl2.Load(clsData.getReader(sqlImage));
                    Cpt21.Subreports["picrep.rpt"].SetDataSource((DataTable)dTable);//picrep 子报表
                        //Cpt21.Refresh();
                        //Cpt21.Refresh();
                    rd.Close();
                    conn.Close();
                }
                catch (Exception E)
                {
                    MessageBox.Show(E.Message);
                }
               
            }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

扬帆破浪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值