水晶报表设计(三)----PUSH模式(二)——转自肖锰的专栏

首先解释一个PULL模式和PUSH模式的区别: 1、PULL模式:与数据库紧耦合模式。也就是说,当数据库位置发生变化的时候,水晶报表就找不到它的数据源了。原因:在给水晶报表建立数据库连接的时候,连接串是存放在水晶报表里面的。比如是127.0.0.1。当数据库位置发生变化的时候,比如变成了127.0.0.2,那么当水晶报表寻找数据源的时候,它仍然会去找第一个ip地址而不是第二个ip地址。这样水晶报表就找不到真正要显示的数据了。 2、PUSH模式:与数据库松耦合模式。在这个模式下,我们借助了“中间件”数据集。数据集负责进行数据库的连接,而水晶报表则是从数据集中提取数据。也就是数据库-->数据集(.xsd)-->水晶报表。需要注意:数据库连接串是放在数据集里面的。这样,我们写一个新的数据库连接来取代数据集的数据库连接,并将执行完后的存储过程返回DataSet(DataTable),然后将它赋值给水晶报表。注意红色字部分,这个部分起的就是数据库-->数据集(.xsd)作用。 下面说一下另外一种PUSH模式。模式依然是数据库-->数据集(.xsd)-->水晶报表。只不过在数据集中不再使用TableAdapter,而是DataTable。 将DataTable拖放到界面上,在上面右键【添加】--【列】,加入我们想要显示的数据列。 T1 然后在后台用代码控制就可以了。 SqlCommand cmd2 = new SqlCommand("TC_Rpt_Select_ZhuangYunQiXian", conn); cmd2.CommandType = CommandType.StoredProcedure; cmd2.Parameters.Add("@value", SqlDbType.VarChar, 200).Value = value; SqlDataAdapter da = new SqlDataAdapter(); da.SelectCommand = cmd2; da.Fill(ds, "zyqx"); 同样我们要注意的是:Fill()中的表名需要和数据集中的表名一样。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值