如何实现一次性统计8个表中的数据[包括打印]

flashasp 2004-11-22 02:02:51
在VB中我想作这样的统计:

一次性统计8个表中的数据,
这8个表的库结构各不相同,
但可以通过唯一标识的帐号把各个表中关联起来.
请问除拉水晶报表外有没有根简单的方法来实现这个报表的统计和分页打印功能
谢谢指点

...全文
275 21 打赏 收藏 转发到动态 举报
写回复
用AI写文章
21 条回复
切换为时间正序
请发表友善的回复…
发表回复
zqm9960 2004-11-30
  • 打赏
  • 举报
回复
用水晶报表很简单的
思路:
1。建一个数据集(DATASET)
2。通过SQL语句把统计出来的记录放入DATASET中
3。在水晶报表中读取DATASET的记录就可以了。水晶报表自带有打印以及导出记录的功能。
flashasp 2004-11-30
  • 打赏
  • 举报
回复
我用SQL写是可以统计正确的结果,但是打印出来的结果和统计的结果不一样,郁闷啊:(
我再vb用的这个控件CURTPRINTER.OCX
wangxiaohu 2004-11-30
  • 打赏
  • 举报
回复
既然表之间有关联,那么用sql语句肯定是可以的!
lyfxzzb 2004-11-30
  • 打赏
  • 举报
回复
八个表也可以写连接
不过建议写存储过程中,那样效率还一些吧
goody9807 2004-11-30
  • 打赏
  • 举报
回复
现有的Web打印控制技术分成几种方案
  自定义控件完成打印
  利用IE自带的WebBrowser控件实现打印
  利用第三方控件实现打印
以下主要谈前两个方面的内容

一、 自定义控件方式
自定义控件方式就是利用VB或VC等工具生成COM组件,用定义好的打印格式来分析打印源文件从而实现打印。只有将生成的组件下载并注册到客户机上,才能实现在客户端的打印。
难点主要是定义打印格式、如何来分析打印源文件。现有的比较好的方法是利用XML技术来全面的解决问题,利用XML可以非常容易地定义打印目标的文本、表格等内容的格式。但对程序员的开发要求高,难度比较大。

二、 利用WebBrowser实现Web打印
WebBrowser是IE内置的浏览器控件,无需用户下载。本文档所讨论的是有关IE6.0版本的WebBrowser控件技术内容。与其相关的技术要求有:打印文档的生成、页面设置、打印操作的实现等几个环节。

(一)、 打印文档的生成
1、 客户端脚本方式
客户端脚本分为VBScript、JavaScript、JScript几种脚本语言。在IE下开发应用使用的语法为JScript的语法,由于它和JavaScript几乎没有什么区别,所以也可以称其为JavaScript(下面简写为JS)。一般情况下,主要使用JS来实现DOM文档的分析,DOM为微软提出的一种Web文档模型,主要用来实现Web脚本编程。
利用JS可以分析源页面的内容,将欲打印的页面元素提取出来,实现打印。通过分析源文档的内容,可以生成打印目标文档。

优点:客户端独立完成打印目标文档的生成,减轻服务器负荷;
缺点:源文档的分析操作复杂,并且源文档中的打印内容要有约定;

2、 服务器端程序方式
服务器端程序方式,主要是利用后台代码从数据库中读取打印源,生成打印目标文档。当的页面生成时,还应适当考虑使用CSS来实现强制分页控制。

优点:可以生成内容非常的丰富的打印目标文档,目标文档的内容的可控性强。由于打印内容是从数据库中获取的,所以生成操作相对简单;
缺点:服务器端负载比较大;

(二)、 页面设置
页面设置主要是指设置打印文档的页边距、页眉、页脚、纸张等内容。页面设置将直接影响到打印文档版面的生成效果,所以它和打印文档的生成有着密切的关系。比如:表格的行数、大小、位置、字体的大小等。
现有的技术是利用IE6.0内置的打印模板方式来控制页面设置,其可以对打印目标文档产生非常大的影响。打印模板可以控制页边距、页眉、页脚、奇偶页等内容,并可以将用户的设置取得,还可以将设置发送到服务器端。
打印模板技术可以自定预览窗口和打印格式,最大限度地影响目标文档和打印效果。

(三)、 打印操作的实现
此功能的实现主要是利用WebBrowser控件的函数接口来实现打印、打印预览(默认的)、页面设置(默认的)。
<object ID='WebBrowser1' WIDTH=0 HEIGHT=0
CLASSID='CLSID:8856F961-340A-11D0-A96B-00C04FD705A2'>
//打印
WebBrowser1.ExecWB(6,1);
//打印设置
WebBrowser1.ExecWB(8,1);
//打印预览
WebBrowser1.ExecWB(7,1);

三、 本项目采用的打印方案
服务器端程序方式、打印预览接口调用,下面为例,主要参考项目中的:pageErrorPrint.aspx.vb文件
主调用页
function PrintPage(iPageIndex,strQuery)
{
var strURL;
strURL = "PageErrorPrint.aspx?PageIndex=" + iPageIndex + "&QueryString=" + strQuery;
winPrint=window.open(strURL,"","left=2000,top=2000,fullscreen=3");
}

打印页HTML源中的预览控制
<SCRIPT language="javascript">function print(){
document.write("<object ID='WebBrowser' WIDTH=0 HEIGHT=0
CLASSID='CLSID:8856F961-340A-11D0-A96B-00C04FD705A2'></object>");
WebBrowser.ExecWB(7,1);
window.opener=null;
window.close();}
</SCRIPT>
yghuang96 2004-11-30
  • 打赏
  • 举报
回复
可以考虑用视图
tengjian1981 2004-11-30
  • 打赏
  • 举报
回复
用SQL语句,将8个表合成一个数据集,再用普通的打印控件打印就行了.
xl1860 2004-11-30
  • 打赏
  • 举报
回复
看不懂
JadyZhu 2004-11-30
  • 打赏
  • 举报
回复
先用存储过程得到结果集,返回结果表到报表打印
wuhaifeng558 2004-11-30
  • 打赏
  • 举报
回复
没有接触过

nga96 2004-11-30
  • 打赏
  • 举报
回复
difficult
苏陌Bubble 2004-11-28
  • 打赏
  • 举报
回复
如果是表,没有不能统计的,只不过步骤的多少而己,但是???你表结构都不说,
表字段也不知道,我们怎么知道你要的是什么?
搞不懂.
gohome123 2004-11-27
  • 打赏
  • 举报
回复
这个完全可以实现,从后台代码实现,不过代码过长,不能粘帖在上面可以通过QQ联系。394142906
flashasp 2004-11-26
  • 打赏
  • 举报
回复
如果能用asp.net+sqlserver+水晶报表实现也可以^_^
flashasp 2004-11-23
  • 打赏
  • 举报
回复
哈哈,有解吗^_^
二师兄的老公 2004-11-23
  • 打赏
  • 举报
回复
SQL的表联结没学过?没救了!
cdwq88 2004-11-22
  • 打赏
  • 举报
回复
发我的Email:cdwq88@163.com,注明“打印控件”可以实现。
flashasp 2004-11-22
  • 打赏
  • 举报
回复
我可不可以直接在报表文件中设计查询语句,从程序中传递查询参数呢^_^
flashasp 2004-11-22
  • 打赏
  • 举报
回复
建立临时表??就是说水晶报表不支持多个ado?
具体一点可以吗,楼上的兄弟
viena 2004-11-22
  • 打赏
  • 举报
回复
自己做啊
加载更多回复(1)

62,041

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧