我想用ASP实现打开页面后实时输出数据库表中所有内容,感激不尽,代码越少越好

我想用ASP实现打开页面后实时输出数据库表中所有内容,感激不尽,代码越少越好,第1张

实时数据库“StrongDas”在内蒙“包钢”的应用

1、系统概述

包钢燃气厂是包钢各二级厂矿和民用煤气的主要处理和供应单位,工作地点分散,现有的高炉煤气净化站、轧钢加压站、薄板加压站、二炼钢加压站等十几个自动控制系统都是各自独立运行,无法实现数据共享和统一调度,严重地制约了生产自动化的发展。因此我们根据燃气厂的需求,并考虑到将来网络拓展与维护的方便性,采用了一套实时数据库系统“StrongDas” 41来管理大量的实时生产数据。

2、网络结构

整个系统的网络有两层,一层是由现场的自动控制 *** 作站连接而成的工业控制网,另一层是燃气厂的调度室、各科室及车间连接而成的三级管理网络。一级网络和三级网络之间由一台安装双网卡的数据采集接口机进行连接,数据采集接口机将一级的现场数据采集上来送到三级网的实时数据库服务器中,至此便为实现现场数据的共享提供了硬件条件。

3、系统构成

实时数据库系统的硬件由两台服务器和三台数据采集接口机构成,其中一台数据库服务器和一台WEB服务器。数据库服务器储存和处理采集接口机采集上来的所有实时数据及历史数据,数据采集接口机与工业控制网相连,采集所有煤气加压站的实时数据并送至实时数据库服务器。

实时数据库的软件部分由用于过程数据和历史数据的存储的数据库服务器软件StrongDAS 41、为系统提供网页发布的服务的WEB服务器软件StrongDAS Web41、采集接口软件及客户端配置软件组成。

4、数据采集的实施

数据采集接口为大多数厂商的plc和dcs系统提供了数据采集接口,例如dde、opc、文件采集、串口采集等。燃气厂的各个加压站plc和dcs主要由SIMENSE、横河、honeywell TDC3000、贝加莱几个系统组成。

对于SIMENSE、横河的设备通过opc接口与实时数据库实现通讯,利用StrongDasIOClient 41中的StrongIO_configure即可以对opc进行配置,软件包中的strongio_opc_read_cache既可从opc服务器缓冲区读取数据,strongio_opc_read_cache和opc服务器进行数据交互有2种不同方式,即同步方式和异步方式,本系统采用的时同步方式。 实时数据库系统连接的装置必须启动相应的opcSerever。在StrongIO_configure中定义系统所将要读取装置的主机名称以及对方提供的opcServer名称(如WINCC 为opcServerWinCC)。

对于贝加莱设备采用网络dde(Dynamic Data Exchange)接口进行配置,启动远程的dde服务后,建立一个dde共享即ddeShare,设置这个共享为所有程序均可访问,然后在信任共享中设为允许启动程序和允许初始化应用程序。在StrongIO_configure中配置dde时,将Application的名称设为\\computerName\\Ndde$,Topic设为在远程计算机上所建好的ddeShare的名称。dde接口也是一种比较稳定的数据交换接口。

对于4#trt的TDC3000 控制系统,它本身没有提供标准的opc和dde的接口,所以采用串口通讯的方式利用StrongDasIOClient 41中的strongio_honeywell_us进行数据的采集。具体实现的方式是在TDC3000系统中建立包括所有要采集的工位的打印报表,并将报表打印模式设为按一定的时间间隔打印,从打印机的串口接一根特制的串口通讯电缆与数据采集接口机相连。在StrongIO_configure 中对采集项进行相应的配置即可完成对TDC3000的数据采集。

所有类型的采集接口均采用一个数据标签配置文件对需采集的工位信息进行配置并实现与数据库服务器中的数据表的对接。

一 前言

这个问题是上一篇文章《Oracle跨数据库实现定时同步指定表中的数据》中所提问题的进一步延伸。考虑到对数据的实时性要求比较高,设置成定时同步,有点不妥,需要改善升级更改为实时同步。

下面介绍到的方式,严格意义上说,并没有实现实时同步。是通过Oracle数据库创建同义词+DBlink的方式,来建立远程映射。在查看数据时,直接去远程查询源库中的表。

而我一直关注的是如何进行同步数据,却没有考虑到可以建立映射。另外,还有一点就是需要交代,就是同步到目标数据库中的表,不进行增删改 *** 作,只进行查询的 *** 作,这也是可以使用同义词方式解决问题的关键。

这种解决思路的出现,多亏了在CSDN问答时,热心网友的回答,下面就是问题详情描述。

二 问题描述

有两个Oracle数据库,分别布置在不同的服务器上,系统均为windows2003;

这里暂且说成是一个主数据库和从数据库:

(1) 主数据库:oracle_A;

(2) 从数据库:oracle_B;

在oracle_A中有一个表table_A与oracle_B中的表table_B结构相同;

我是处在oracle_B,oracle_A数据库分配给我有一个访问oracle_A表table_A的用户,该用户只拥有查询的权限;

另外,需要说明的一点,就是在oracle_B处,只需对table_B表进行查询的 *** 作,不进行其他增删改的 *** 作。

场景介绍完了,我的问题的是,如何在oracle_A中表table_A发生变化时,实时更新同步到oracle_B的table_B中

我原来的处理方式:

通过建立远程连接DBLink+JOB定时任务+存储过程的方式,实现了定时同步更新,但不能做到实时同步。

三 采用同义词+DB_Link的方式结果步骤

之所以能够选择采用同义词的方式,处理这个问题。主要还是源于在问题描述中提到一个点,那就是我们只需要对同步后的表进行查询 *** 作。这点是使用同义词方式的重要要素。

下面详细模拟一下整个实验测试的过程:

(1)首先在Oracle_A端创建一个对table_A只有查询功能的用户

<1> 创建用户

sqlplus /nolog

conn /as sysdba;

create user username identified by password;

<2> 查看所有的用户列表

用户创建完成后,查看用户是否创建成功

select from all_users;

<3>授予权限

为了能够保证能够登陆,必须赋予如下权限

--授予username用户创建session的权限,即登陆权限

grant create session to username;

--授予username用户使用表空间的权限

grant unlimited tablespace to username;

--oracle对权限管理比较严谨,普通用户之间也是默认不能互相访问的,需要互相授权

--如果scott用户要授权给username用户查看自己的test表的权限;

sqlplus scott/tiget@localhost:1521/orcl

--授予username用户查看指定的权限

grant select on test to username;

--撤销权限

基本语法同grant,关键字为revoke;

(2)验证用户是否可以成功登录,并进行访问授权的表

--使用sqlplus登录,并进行查询

sqlplus username/password@localhost:1521/orcl;

select from scotttest;

注意:查询表时,务必带上用户名,说明是哪个用户下的表。

(3)创建远程连接DB_Link

<1> 创建远程连接 db_link

create public database link db32 connect to tianzhi_test identified by "tianzhi_test" using '192168566:1521/ORCL'

<2> 测试远程连接是否成功

select from tianzhi_smartzh_item_news@db32;

(4)在Oracle_B端创建同义词

<1> 使用sqlplus登录自己的用户

sqlplus tianzhi_smart/tianzhi_smart@localhost:1521/orcl

<2> 创建同义词

create or replace public synonym TEST1130 for scottTEST@db32;

<3> 查询测试

select from TEST1130;

可以看到这与在Oracle_A源数据库中查到的table_A表中的数据一样

注意事项:

当远程查询的数据库中包含BLOB字段时,会报出如下错误

ORA-22992: 无法使用从远程表选择的 LOB 定位器

当出现这个错误的时候,那是因为跨库连接查询中的表中存在BLOB类型的字段,所以一定要注意,所有表中存在blob类型字段,

不能用 select from 连接的表

不能将blob类型的字段出现在脚本中。

如果这些blob类型的字段一定要导过来,可以先建立临时表再插入本地表,方法如下在pl/sql中执行

第一步 建临时表

create global temporary table foo ( X BLOB )

on commit delete rows;

第二步 插入本地表

insert into foo select blobcolumn from remoteTable@dl_remote ;

以上就是关于我想用ASP实现打开页面后实时输出数据库表中所有内容,感激不尽,代码越少越好全部的内容,包括:我想用ASP实现打开页面后实时输出数据库表中所有内容,感激不尽,代码越少越好、mysql同一数据库不同表实时同步、2019数据架构选型必读:1月数据库产品技术解析等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9478057.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-28
下一篇 2023-04-28

发表评论

登录后才能评论

评论列表(0条)

保存