PageOffice ZoomSeal ZDFOffice 技术支持 合作伙伴 会员登录 如何购买

PageOffice与数据库的关系

     PageOffice产品和数据库是两个独立的概念,严格来说两者之间没有任何本质关系。PageOffice不依赖数据库而存在,但是数据库和PageOffice可以结合使用来完成某些复杂的业务逻辑。例如:PageOffice可以将数据库中数据的动态填充到Word或Excel文档中,还可以打开数据库中的二进制流文件,也可以将Word或者Excel整个文档或者文档中的一部分数据保存到数据库中,这里的数据库可以是任意数据库,如:Sqlite,Access,SQL Server,Oracle,MySQL,DB2,Sybase等。下面我们就PageOffice和数据库的结合使用展开详细论述。

 

一.动态填充数据库中的数据到文档中(以JAVA语言,Word文档,Sqlite数据库为例).

复制代码
    PageOfficeCtrl poCtrl1 = new PageOfficeCtrl(request);
    poCtrl1.setServerPage(request.getContextPath()+"/poserver.zz"); //此行必须     //连接数据库并获得数据库中的字段值
    Class.forName("org.sqlite.JDBC");
    String strUrl = "jdbc:sqlite:"
             + this.getServletContext().getRealPath("demodata/" + "\\demo.db";
    Connection conn = DriverManager.getConnection(strUrl);
    Statement stmt = conn.createStatement();
    ResultSet rs = stmt.executeQuery("select * from user where id =1”);
    if (rs.next()) {
        String name=rs.getString(“name”);
        String deptNum=rs.getString(“deptNum”);
    }

    rs.close();
    conn.close();

   //将获取的数据填充到word文档只读的数据区域中
    WordDocument doc = new WordDocument();

   //打开数据区域
    DataRegion dataRegion1 = doc.openDataRegion("PO_userName");

    //给数据区域填充获取的字段值赋值
    dataRegion1.setValue(name);
    DataRegion dataRegion2 = doc.openDataRegion("PO_deptName");
    dataRegion2.setValue(deptNum);
    poCtrl1.setWriter(doc);
    poCtrl1.webOpen("doc/test.doc", OpenModeType.docNormalEdit, "张三");
    poCtrl1.setTagId("PageOfficeCtrl1"); //此行必须
复制代码

 

二.以流的形式读取数据库中的文件(以JAVA语言,Word文件,Sqlite数据库为例)

1)打开文档的Stream.jsp页面:

复制代码
    PageOfficeCtrl poCtrl1 = new PageOfficeCtrl(request);
    poCtrl1.setServerPage(request.getContextPath()+"/poserver.zz"); //此行必须
    ……
    poCtrl1.setSaveFilePage("SaveFile.jsp?id=1");
    poCtrl1.webOpen("Openstream.jsp?id=1", OpenModeType.docNormalEdit, "张三");
    poCtrl1.setTagId("PageOfficeCtrl1"); //此行必须
复制代码

 

2)下载文档的Openstream.jsp页面:

复制代码
    String id = "1";
    if (request.getParameter("id") != null
            && request.getParameter("id").trim().length() > 0) {
        id = request.getParameter("id");
    }
    Class.forName("org.sqlite.JDBC");
String strUrl = "jdbc:sqlite:"
             + this.getServletContext().getRealPath("demodata/"
 + "\\DataBase.db";
    Connection conn = DriverManager.getConnection(strUrl);
    Statement stmt = conn.createStatement();
    ResultSet rs = stmt.executeQuery("select * from stream where id = "+ id);

    int newID = 1;

    if (rs.next()) {
        //******读取磁盘文件,输出文件流 开始****
        byte[] imageBytes = rs.getBytes("Word");
        int fileSize = imageBytes.length;
        response.reset();
        response.setContentType("application/msword");

 // application/x-excel, application/ms-powerpoint, application/pdf
        response.setHeader("Content-Disposition", "attachment; filename=down.doc"); //fileN应该是编码后的(utf-8)
        response.setContentLength(fileSize);
        OutputStream outputStream = response.getOutputStream();
        outputStream.write(imageBytes);
        outputStream.flush();
        outputStream.close();
        outputStream = null;
        //******读取磁盘文件,输出文件流 结束*************
    }
    rs.close();
    conn.close();
复制代码

 

 

                           图1  以流的形式打开数据库中的文档

 

注:该示例的完整代码和详细演示请参考Samples或者Samples4的二、2、打开保存数据库中的文件(以Word为例)程序包,同时结合PageOffice开发帮助.

 

 

 

注: 不推荐把文件保存在数据库中,不便于调试,并且影响数据库的查询速度。

 

 

三.获取文档的纯文本或者二进制流数组保存到数据库(以JAVA语言,Word文件为例)

保存文档的SaveFile.jsp页面的代码:

复制代码
FileSaver fs=new FileSaver(request,response);
//返回控件提交的文档二进制流字节数组
byte[]  bytes=fs. getFileBytes();
//获取文档的纯文本内容。 获取文档的纯文本内容,不带任何附加格式。如果把此文本字符串保存到数据库字段,可以简单利用SQL语句轻松实现文档管理中的全文检索功能。
String  fileText=fs. getDocumentText();
//连接数据库,将控件返回的文档纯文本或者文档二进制流数组保存到数据库,此处代码省略,开发人员可以根据自己的需求选择连接相应的数据库
……
fs.close();
复制代码

 

四.获取文档指定区域的数据保存到数据库(以JAVA语言,Word文件为例)

保存数据的SaveData.jsp页面(包属于com.zhuozhengsoft.pageoffice.wordreader.*):

复制代码
   WordDocument doc = new WordDocument(request, response);
   //获取提交的数值
   DataRegion dataUserName = doc.openDataRegion("PO_userName");
   DataRegion dataDeptName = doc.openDataRegion("PO_deptName");
   //连接数据库,将获取的数据区域的数据保存到数据库,此处代码省略,开发人员可以根据自己的需求选择连接相应的数据库.
   ......
   doc.close();
复制代码
返回顶部 在线购买 下载中心 400-6600-770 2692936468