目的:从数据库中得到本地图片的路径,再将其打印到报表上,每一个ID查询出来的信息(包括多幅图片)对应报表中的一页
环境:VS2005+自带水晶报表
参考文献:http://babyt.cnblogs.com/archive/2005/04/21/142789.html 阿泰BLOG
遇到的问题:http://topic.csdn.net/u/20090925/16/1cf16b4d-e7a4-4d3c-a7c6-5850862cd5fb.html?71028
基本思想:在数据库里添加图片字段,SQL Server把它们称作 BLOB (二进制大型对象) 字段,将其映射到报表上
需要说明的是:下图中表UriResult1是强类型,也就是说如果要在该表手动添加其它表字段的时候,当联合查询数据库,并将查询
出来的值赋给UriResult1时候会报"未能启用约束.一行或多行中包含违反非空 唯一或外键约束的值",这个时候
可以采用弱类型,即手动生成UriResult1.如果UriResult1只对应一张表,则不会报错
这里就不介绍详细步骤了,只把核心的内容记录下
1.数据库用到的表
ChemResult SickInfo UriResult
由于图片不存储在数据库,但是为了显示在报表上,需要在某张表中添加图片的字段,作为映射用,这里在UriResult添加了6个图片字段
2.手动添加一个DataSet,取名为AveDataSet,其中AveDataSet.xsd文件如图一所示:
图一
需要说明的是:如图所示,UriResult1为表UriResult的别名,是从服务器资源管理器里拖进AveDataSet.xsd里的
DataTable1为工具箱里拖进来的DataTable,其中的8个字段都是手动一行一行添加的
注意以上两个Table的字段名,以及格式都要统一,否则会报错的,而且还要添加他们的关系,字段也是一一对应
这里我设定的是 DataTable1为父表, UriResult1为字表
3.打开报表,设定表的关系
图二 图三
这里图二表示数据库连接,将数据集中的映射表DataTable1与数据库的三张表连接
图三表示各表内连接的关系,每两个字段确定一条数据,这里特别提醒,不要有分支,否则报表会有很多不需要的数据显示
4.把数据库专家里面DataTable1的字段拖进报表的详细资料里面
5.实现的代码