CN111162995A - 一种数据变更通知方法、装置、设备及可读存储介质 - Google Patents
一种数据变更通知方法、装置、设备及可读存储介质 Download PDFInfo
- Publication number
- CN111162995A CN111162995A CN201911367788.9A CN201911367788A CN111162995A CN 111162995 A CN111162995 A CN 111162995A CN 201911367788 A CN201911367788 A CN 201911367788A CN 111162995 A CN111162995 A CN 111162995A
- Authority
- CN
- China
- Prior art keywords
- data
- data table
- target data
- database
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
- 238000000034 method Methods 0.000 title claims abstract description 49
- 239000000463 material Substances 0.000 claims description 11
- 238000004590 computer program Methods 0.000 claims description 9
- 238000013475 authorization Methods 0.000 claims description 8
- 238000012544 monitoring process Methods 0.000 claims description 7
- 238000012216 screening Methods 0.000 claims description 7
- 238000012546 transfer Methods 0.000 claims description 4
- 230000000737 periodic effect Effects 0.000 abstract description 4
- 238000010586 diagram Methods 0.000 description 9
- 241000282326 Felis catus Species 0.000 description 3
- 230000000694 effects Effects 0.000 description 3
- 230000006870 function Effects 0.000 description 2
- 238000012545 processing Methods 0.000 description 2
- 238000012360 testing method Methods 0.000 description 2
- 238000013461 design Methods 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 230000007774 longterm Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000002085 persistent effect Effects 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
- 230000001360 synchronised effect Effects 0.000 description 1
- 230000001052 transient effect Effects 0.000 description 1
- 230000001960 triggered effect Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L51/00—User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail
- H04L51/42—Mailbox-related aspects, e.g. synchronisation of mailboxes
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/22—Indexing; Data structures therefor; Storage structures
- G06F16/2282—Tablespace storage structures; Management thereof
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/23—Updating
- G06F16/2358—Change logging, detection, and notification
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L51/00—User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail
- H04L51/07—User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail characterised by the inclusion of specific contents
- H04L51/08—Annexed information, e.g. attachments
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L51/00—User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail
- H04L51/21—Monitoring or handling of messages
- H04L51/23—Reliability checks, e.g. acknowledgments or fault reporting
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Data Mining & Analysis (AREA)
- Databases & Information Systems (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Software Systems (AREA)
- Information Transfer Between Computers (AREA)
Abstract
本发明公开了一种数据变更通知方法、装置、设备及可读存储介质,该方法包括以下步骤:定期获取数据库中指定类别数据或指定类别数据组合对应的目标数据表,以及与目标数据表对应的历史数据表;对比目标数据表和历史数据表,确定数据库是否新增/删除目标数据;如果是,则生成目标数据对应的通知邮件,并在发送通知邮件后利用目标数据表更新历史数据表。本方法可实现自动化、周期性地监管数据库中的特殊数据,并在发现特殊数据时,向用户及时反馈邮件,以便用户获知数据变更情况。
Description
技术领域
本发明涉及存储技术领域,特别是涉及一种数据变更通知方法、装置、设备及可读存储介质。
背景技术
众所周知,使用mysql(一个关系型数据库管理系统)等数据库相关命令可以对数据库中的海量数据库进行查找、筛选、修改、新增以及删除等操作,以达到查看所需要信息的目的。
在一些特殊的场景下,如特殊订单审核、库房特殊物品管理中,需要对数据库中的某些数据进行长期、及时、有效的审核/监管。虽然,通过数据库相关命令方式可确定数据库的数据变更,查找特殊数据,但无法长期有效的进行监管,无法及时发现特殊订单。
综上所述,如何及时有效的获知数据库中特殊数据变更等问题,是目前本领域技术人员急需解决的技术问题。
发明内容
本发明的目的是提供一种数据变更通知方法、装置、设备及可读存储介质,通过周期性查询数据库,在出现指定类型数据或指定类型数据组合变更时,发出邮件通知。
为解决上述技术问题,本发明提供如下技术方案:
一种数据变更通知方法,应用于linux系统中,包括:
定期获取数据库中指定类别数据或指定类别数据组合对应的目标数据表,以及与所述目标数据表对应的历史数据表;
对比所述目标数据表和所述历史数据表,确定所述数据库是否新增/删除目标数据;
如果是,则生成所述目标数据对应的通知邮件,并在发送所述通知邮件后利用所述目标数据表更新所述历史数据表。
优选地,发送所述通知邮件,包括:
基于授权码和简单邮件传送协议将所述通知邮件发送至Windows系统下的邮件终端。
优选地,所述定期获取数据库中指定类别数据或指定类别数据组合对应的目标数据表,以及与所述目标数据表对应的历史数据表,包括:
利用crontab命令定期获取所述目标数据表和所述历史数据表。
优选地,所述生成目标数据对应的通知邮件,包括:
利用所述目标数据为邮件变量进行赋值,生成所述通知邮件;所述邮件变量对应邮件主题、邮件正文或邮件附件。
优选地,当所述数据库用于存储设备订单数据时,所述目标数据表具体为目标设备订单表,所述历史数据表具体为历史设备订单表;定期获取数据库中指定类别数据或指定类别数据组合对应的目标数据表,以及与所述目标数据表对应的历史数据表,包括:
定期获取数据库中的材料列表和订单列表;
利用所述材料列表和所述订单列表筛选出具有指定类型器件或指定类型器件组合的所述目标设备订单表;
读取具有所述指定类型器件或所述指定类型器件组合的所述历史设备订单表。
优选地,对比所述目标数据表和所述历史数据表,确定所述数据库是否新增/删除目标数据,包括:
对比所述目标设备订单表和所述历史设备订单表,确定出所述数据库是否新增/删除特殊设备订单。
优选地,所述生成所述目标数据对应的通知邮件,包括:
将所述特殊设备订单的订单号添加至特殊订单列表中;
将所述特殊订单列表添加在所述通知邮件中。
一种数据变更通知装置,应用于linux系统中,包括:
数据读取模块,用于定期获取数据库中指定类别数据或指定类别数据组合对应的目标数据表,以及与所述目标数据表对应的历史数据表;
数据监测模块,用于对比所述目标数据表和所述历史数据表,确定所述数据库是否新增/删除目标数据;
邮件通知模块,用于如果所述数据库新增/删除所述目标数据,则生成所述目标数据对应的通知邮件,并在发送所述通知邮件后利用所述目标数据表更新所述历史数据表。
一种数据变更通知设备,包括:
存储器,用于存储计算机程序;
处理器,用于执行所述计算机程序时实现上述数据变更通知方法的步骤。
一种可读存储介质,所述可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现上述数据变更通知方法的步骤。
在linux系统中应用本发明实施例所提供的方法,定期获取数据库中指定类别数据或指定类别数据组合对应的目标数据表,以及与目标数据表对应的历史数据表;对比目标数据表和历史数据表,确定数据库是否新增/删除目标数据;如果是,则生成目标数据对应的通知邮件,并在发送通知邮件后利用目标数据表更新历史数据表。
在本方法中,通过定期获取数据库中的指定类别数据或指定类别数据组合对应的目标数据表,以及该目标数据表对应的历史数据表。然后通过比对目标数据表和历史数据表便可确定出数据库中是否新增/或删除了目标数据。如果是,则生成并发送该目标数据对应的通知邮件。在发送通知邮件之后,利用目标数据表对历史数据表进行更新,以便后续通过目标数据表和更新后的历史数据表发现数据变更对应的目标数据,并发送邮件通知用户。可见,本方法可实现自动化、周期性地监管数据库中的特殊数据,并在发现特殊数据时,向用户及时反馈邮件,以便用户获知数据变更情况。
相应地,本发明实施例还提供了与上述数据变更通知方法相对应的数据变更通知装置、设备和可读存储介质,具有上述技术效果,在此不再赘述。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为本发明实施例中一种数据变更通知方法的实施流程图;
图2为本发明实施例中一种数据变更通知方法的具体实施示意图;
图3为本发明实施例中一种通知邮件示意图;
图4为本发明实施例中一种数据变更通知装置的结构示意图;
图5为本发明实施例中一种数据变更通知设备的结构示意图;
图6为本发明实施例中一种数据变更通知设备的具体结构示意图。
具体实施方式
为了使本技术领域的人员更好地理解本发明方案,下面结合附图和具体实施方式对本发明作进一步的详细说明。显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
实施例一:
请参考图1,图1为本发明实施例中一种数据变更通知方法的流程图,应用于linux系统中,该方法包括以下步骤:
S101、定期获取数据库中指定类别数据或指定类别数据组合对应的目标数据表,以及与目标数据表对应的历史数据表。
其中,数据库可以为任意一个需要监管其内存放的指定类别数据或指定类别数据组合的数据库。
在本实施例中,可预先确定出需要监控的指定类别数据或指定类别数据组合。其中,指定类别数据以及指定类别数据组合可具体根据实际应用场景而定,也就是说想要对数据库中存储的哪个类别或哪些类别的对应组合进行监测并通知,则可对将相应类别对应数据设置为指定类别数据,或将2个以上的相应类别对应数据设置为指定类别数据组合。
通常,一个服务器可存储多个数据库,每个数据库又可包括多个数据表,具体的数据信息存储在数据表中。因此,要确定是否出现指定类别数据或指定类别数据组合的数据变更,可通过查找数据表即可获知。
具体的,获取数据库中的目标数据表的周期可根据具体的监管需求的实时性需求进行设置,例如,对于实时性要求较高的场景下,周期频率可设置为较高频率(如15分钟);对于实时性要求较低的场景下,周期频率可设置为较低频率(如1天)。
具体的,可利用crontab命令定期获取目标数据表和历史数据表。其中, crontab命令是linux操作系统下用来提交和管理用户的需要周期性执行的任务,与windows下的计划任务类似,当安装完成操作系统后,默认会安装此服务工具。在Linux系统下使用crontab–e命令来定制任务执行的时间或周期。具体格式举例:*****/xx/xx/a.sh
其中五个星号(*)从前到后代表分、时、日、月、周,/xx/xx/代表待执行的任务程序所在目录,a.sh代表任务程序(此处以.sh结尾的是linux系统下 shell工具,名称为a);crontab–e命令执行后弹出编辑窗口。例如,输入*/30 ****/home/mailnotice.sh,即表示每三十分钟执行一次home目录下的 mailnotice程序(邮件提醒程序,即本发明实施例所提供的数据变更通知方法对应的程序)。
需要特别说明的是,目标数据表即为包括了数据库中全部的指定类别数据或使得拷贝数据组合对应的数据表,而历史数据表为上一周期检测时,对应的数据库中全部的指定类别数据或指定类别数据组合对应的数据表。也就是说,当前周期与上一周期之间,若未发送指定类别数据或指定列表数据组合的数据变更,目标数据表与历史数据表应当一致;而当前周期与上一周期之间,若发生了指定类别数据或指定列表数据组合的数据变更,则目标数据表与历史数据表会存在差异,这个差异可具体为当新增数据,则目标数据表多一些差异数据;当删除数据,则目标数据表少一些差异数据;若为数据修改,则数据值存在差异。
S102、对比目标数据表和历史数据表,确定数据库是否新增/删除目标数据。
在拿到目标数据表和历史数据表之后,可比对目标数据表和历史数据表,然后确定出数据库中是否新增/删除目标数据。具体的,在对比目标数据表和历史数据表时,可一一比对目标数据表和历史数据表记录的全部数据。具体的数据比对过程可参见现有的数据比对实现过程,在此不再一一赘述。
优选地,减少无效比对带来的资源耗费,还可分别计算出目标数据表和历史数据表的哈希值,当哈希值一致,即可确定目标数据表与历史数据表相同,数据库未新增或删除目标数据;当哈希值不一致则进一步比对得出目标数据。
如果是,则执行步骤S103的操作;如果否,则可无相应操作。
S103、生成目标数据对应的通知邮件,并在发送通知邮件后利用目标数据表更新历史数据表。
在确定出目标数据表与历史数据表之间存在目标数据即差异数据之后,便可生成目标数据对应的通知邮件。
其中,生成目标数据对应的通知邮件,可具体为利用目标数据为邮件变量进行赋值,生成通知邮件;邮件变量对应邮件主题、邮件正文或邮件附件。也就是说,本发明实施例中,从发出的通知邮件的邮件主题、邮件正文或邮件附件中,便可确定出数据变更情况。具体的,在实际应用中,还可在邮件主题、邮件正文或邮件附件中均体现目标数据的变化。
其中,发送通知邮件,可具体为基于授权码和简单邮件传送协议将通知邮件发送至Windows系统下的邮件终端。具体的,可申请一个外部邮箱,并开通授权码。大部分的外部邮件服务使用第三方客户端时,都需要使用授权码,下面的smtp-auth-password使用的即授权码,而不是邮件帐号的密码。具体的设置方式:
cd/etc
vim/etc/mail.rc;
ignore received in-reply-to message-id references
ignore mime-version content-transfer-encoding
#Only include selected header fields when forwarding messages.
fwdretain subject date from to
#For Linux and BSD,this should be set.
set bsdcompat
set from=shilinan111@163.com
set smtp=smtp.163.com
set smtp-auth-user=shilinan111@163.com
set smtp-auth-password=shilinan111
set smtp-auth=login
即cd进入linux系统的ect目录,使用vim编辑mail.rc文件,在文件最后加入申请邮箱的相关信息,其中set from与set smtp-auth-user对应为邮箱账号;163的smtp服务器地址为smtp.163.com;set smtp-auth-password对应邮箱的授权码;set smtp-auth对应login。
在配置mail.rc文件之后,需要将smtp服务器地址IP加入hosts文件 (/etc/hosts),如上,smtp服务器地址为smtp.163.com,其对应IP可使用ping 命令查询,具体操作如下:
PING smtp.163.com(123.126.97.5)56(84)bytes of data.
64bytes from smtp.163.com(123.126.97.5):icmp_seq=1 ttl=49time=38.4ms
64bytes from smtp.163.com(123.126.97.5):icmp_seq=2 ttl=49time=38.2ms
64bytes from smtp.163.com(123.126.97.5):icmp_seq=3 ttl=49time=37.9ms
64bytes from smtp.163.com(123.126.97.5):icmp_seq=4 ttl=49time=37.9ms
64bytes from smtp.163.com(123.126.97.5):icmp_seq=5 ttl=49time=38.9ms
Hosts-The static table lookup for host name(主机名查询静态表)
hosts在/etc目录下,vim是linux系统下编辑文本文件的工具命令,vim /etc/hosts作用是编辑/etc目录下的文件-hosts,以下是本例中hosts文件中的内容:
vim/etc/hosts
127.0.0.1 localhost localhost.localdomain localhost4localhost4.localdomain4
::1 localhost localhost.localdomain localhost6localhost6.localdomain6
123.126.97.5 smtp.163.com
为了后续能够继续及时有效的发现数据库中的特殊数据变更,在发送通知邮件之后,可利用目标数据表更新历史数据表,即将历史数据表同步至与目标数据表一致。
在linux系统中应用本发明实施例所提供的方法,定期获取数据库中指定类别数据或指定类别数据组合对应的目标数据表,以及与目标数据表对应的历史数据表;对比目标数据表和历史数据表,确定数据库是否新增/删除目标数据;如果是,则生成目标数据对应的通知邮件,并在发送通知邮件后利用目标数据表更新历史数据表。
在本方法中,通过定期获取数据库中的指定类别数据或指定类别数据组合对应的目标数据表,以及该目标数据表对应的历史数据表。然后通过比对目标数据表和历史数据表便可确定出数据库中是否新增/或删除了目标数据。如果是,则生成并发送该目标数据对应的通知邮件。在发送通知邮件之后,利用目标数据表对历史数据表进行更新,以便后续通过目标数据表和更新后的历史数据表发现数据变更对应的目标数据,并发送邮件通知用户。可见,本方法可实现自动化、周期性地监管数据库中的特殊数据,并在发现特殊数据时,向用户及时反馈邮件,以便用户获知数据变更情况。
需要说明的是,基于上述实施例,本发明实施例还提供了相应的改进方案。在优选/改进实施例中涉及与上述实施例中相同步骤或相应步骤之间可相互参考,相应的有益效果也可相互参照,在本文的优选/改进实施例中不再一一赘述。
优选地,当数据库用于存储设备订单数据时,目标数据表具体为目标设备订单表,历史数据表具体为历史设备订单表;步骤S101中的定期获取数据库中指定类别数据或指定类别数据组合对应的目标数据表,以及与目标数据表对应的历史数据表,包括:
步骤一、定期获取数据库中的材料列表和订单列表;
步骤二、利用材料列表和订单列表筛选出具有指定类型器件或指定类型器件组合的目标设备订单表;
步骤三、读取具有指定类型器件或指定类型器件组合的历史设备订单表。
相应地,步骤S102中的对比目标数据表和历史数据表,确定数据库是否新增/删除目标数据,可具体为对比目标设备订单表和历史设备订单表,确定出数据库是否新增/删除特殊设备订单。
相应地,步骤S103中的生成目标数据对应的通知邮件,包括:
步骤一、将特殊设备订单的订单号添加至特殊订单列表中;
步骤二、将特殊订单列表添加在通知邮件中。
如此,便可在新增或删除特殊设备订单时,及时邮件通知相关人员进行审核处理。为便于理解,下面结合具体的数据库存储的数据表对上述步骤进行详细说明。先简单介绍一下linux系统下mysql数据库的几个基本操作:
A:查看服务器下的数据库
[root@server1 sln]#mysql-e"show databases"
+-----------------------+
|Database|
+------------------------+
|information_schema|
|laohua|
|mysql|
|preTest|
|test|
+------------------------+
即,Mysql–e”show databases”可见此服务器下有information_schema, laohua,mysql,preTest,test这五个数据库。
B:查看数据库下的数据表:
mysql-e"use laohua;show tables"
+------------------------+
|Tables_in_laohua|
+------------------------+
|AliResult|
|Baidu|
|Bios|
|BoardDiary|
|CheckAli|
|CheckBMC|
|CheckBoard|
|List|
|ListToAli|
|ListToBaidu|
|ListToMaterial|
|ListToOs|
|ListToQihu|
|ListToSN|
此处,以laohua数据库为例,使用mysql-e"use laohua;show tables"命令,可见其包含AliResult,Baidu,Bios,BoardDiary等数据表。
C:查看数据表中的具体数据信息:
[root@server1 sln]#mysql-e"use laohua;select*from ListToMateriallimit 10"
+-------+------------------+----------+----------+-----+
|id|materialId|type|listId|num|
+-------+------------------+----------+----------+-----+
|34025|V194T080P0400000|Heatsink|10110188|2|
|33922|V196X101B130000L|Fan|10110171|3|
|33790|V08CL08000000000|Chassis|10110152|1|
|33789|V12780BHE2223014|CDROM|10110152|1|
|33788|V05H516130E10000|NIC|10110152|1|
|33787|V045L01140M0H003|Board|10110152|1|
|33786|V03HS08140U04000|HD|10110152|4|
|33785|V028407612H0005J|Memory|10110152|4|
|33791|W0C2G00080301000|HD|10110153|10|
|27486|C035401090803008|Cpu|10000085|1|
+-------+------------------+----------+----------+-----+
此处,以ListToMaterial、List为例(都在数据库laohua中),并限制搜索数量为10行,ListToMaterial、List的数据结构分别如下表所示:
上述laohua数据库中和List和ListToMaterial表,是工厂端录入的机型和、订单BOM数据等;其中ListToMaterial(同订单列表)中包含了订单号、订单中使用的物料号、以及每种物料的名称;List(同材料列表)中包含了订单号 -listId,机型-productName,订单包含的机器数量-num,订单配置- productConfiguration以及订单说明-other等项目。
确定所需监控的特殊数据或数据组合,在本实施例中选用监控提醒的特殊数据组合(同指定类型数据组合)为:订单中使用YZNC-00764-101这种物料,并且机型为SA5212M5或NF5280M5,即需要筛选这两种特殊数据组合的订单作为提醒目标,即如果laohua数据库中新增了这种属于SA5212M5或 NF5280M5机型且使用了YZNC-00764-101网卡的订单,就触发邮件提醒。
(说明,此例只对后续新增的此类订单进行提醒,之前存在的此类订单也可以进提醒)
请参考图2,图2为本发明实施例中一种数据变更通知方法的具体实施示意图。首先从laohua数据库中筛选出所需数据,从ListToMaterial中筛选出使用了YZNC-00764-101网卡的订单,然后在List中查询这些订单哪些属于 SA5212M5或NF5280M5机型,确认当前数据库中存在的特殊订单(同特殊设备订单),将这些订单号保存在YZNC764101ori.txt(同目标设备订单表) 中;
按照上述方法,将实时抓取的特殊订单保存在2UM5764101.txt(历史设备订单表)中。
对比两个txt文件,如果有新增特殊订单,则将新增单号加入 YZNC764101ori.txt中,并触发提醒邮件。
由以上数据处理方案可以达成持续新增特殊订单触发邮件提醒的目的。
具体实现过程,可参见以下代码(其中,#符号后的内容属于代码注释):
#!/bin/bash
rm-f/home/sln/mailnotice/764101.txt#删除764101.txt文件
rm-f/home/sln/mailnotice/2UM5764101.txt
#删除2UM5764101.txt文件,即上一次查询的特殊订单列表
mysql-B-N-e"use laohua;select listId from ListToMaterial whereMaterialId='YZNC-00764-101'">>/home/sln/mailnotice/764101.txt
#从laohua数据库的ListToMaterial数据表中筛选出使用了YZNC-00764-101 网卡料号的订单并存入764101.txt
cat/home/sln/mailnotice/764101.txt|while read line#逐行读取764101.txt,即每个单号的同时
do#执行
list=`echo$line`#将每行的数据,即订单号赋予变量list
mysql-B-N-e"use laohua;select listId,productname from List wherelistId='$list'"|grep-E'SA5212M5|NF5280M5'|awk'{print $1}'>>/home/sln/mailnotice/2UM5764101.txt
#在laohua数据库的List列表中查询764101.txt中每个单号的productname-- 机型并筛选出属于SA5212M5|NF5280M5的订单(即本次新增的特殊订单),并将其加入本次查找的特殊订单列表(2UM5764101.txt)
done#结束,与上一个do命令对应
cat/home/sln/mailnotice/2UM5764101.txt|while read line#逐行查找本次的特殊订单列表(2UM5764101.txt)
do#执行
LIST=`echo$line`#将每行的数据,即订单号赋予变量list
cat/home/sln/mailnotice/YZNC764101ori.txt|grep"$LIST">>null#在原有特殊订单列表(YZNC764101ori.txt)中查询本次特殊订单列表 (2UM5764101.txt)内的单号
if[$?-ne 0];then
#如果此单号不在原有特殊订单列表(YZNC764101ori.txt)中
echo"$LIST">>/home/sln/mailnotice/YZNC764101ori.txt#将此单号加入原有特殊订单列表(YZNC764101ori.txt)中,否则就do nothing
echo"NF5280M5/SA5212M5订单$LIST带有YZNC-00764-101网卡,不能使用通用BIOS4.1.11,直到通用BIOS升级或者优化相关功能"|mail-s "NF5280M5/SA5212M5订单$LIST带有YZNC-00764-101网卡提醒" shilinan111@163.com,shilinan@inspur.com,zhangzixinbj@inspur.com,ouyangzf@ inspur.com,zhanghongcai@inspur.com,gaozhunmei@inspur.com,yejianwen@great wall.com.cn,yuanwq@greatwall.com.cn
#如果此单号不在原有特殊订单列表(YZNC764101ori.txt)中,触发邮件提醒,发送邮件给相关人员,格式--echo"邮件内容"|mail-s"邮件标题"收件人A收件人B收件人C
fi#结束,与if对应
done#结束,与do对应
可设置crontab自动每30分钟执行/home/mailnotice.sh程序;Mailnotice.sh调用/home/sln/mailnotice下的noticenic.sh程序;noticenic.sh程序将本次查找的特殊订单列表(2UM5764101.txt)与原有特殊订单列表(YZNC764101ori.txt)比对,筛选出新增特殊订单,将新增特殊订单加入原有特殊订单列表并将此次新增特殊订单触发邮件提醒便可进行有效监管,且及时通知用户。通知效果可参见图3,图3为本发明实施例中一种通知邮件示意图。
实施例二:
相应于上面的方法实施例,本发明实施例还提供了一种数据变更通知装置,可应用于linux系统中,下文描述的数据变更通知装置与上文描述的数据变更通知方法可相互对应参照。
参见图4所示,该装置包括以下模块:
数据读取模块101,用于定期获取数据库中指定类别数据或指定类别数据组合对应的目标数据表,以及与目标数据表对应的历史数据表;
数据监测模块102,用于对比目标数据表和历史数据表,确定数据库是否新增/删除目标数据;
邮件通知模块103,用于如果数据库新增/删除目标数据,则生成目标数据对应的通知邮件,并在发送通知邮件后利用目标数据表更新历史数据表。
在linux系统中应用本发明实施例所提供的装置,定期获取数据库中指定类别数据或指定类别数据组合对应的目标数据表,以及与目标数据表对应的历史数据表;对比目标数据表和历史数据表,确定数据库是否新增/删除目标数据;如果是,则生成目标数据对应的通知邮件,并在发送通知邮件后利用目标数据表更新历史数据表。
在本装置中,通过定期获取数据库中的指定类别数据或指定类别数据组合对应的目标数据表,以及该目标数据表对应的历史数据表。然后通过比对目标数据表和历史数据表便可确定出数据库中是否新增/或删除了目标数据。如果是,则生成并发送该目标数据对应的通知邮件。在发送通知邮件之后,利用目标数据表对历史数据表进行更新,以便后续通过目标数据表和更新后的历史数据表发现数据变更对应的目标数据,并发送邮件通知用户。可见,本装置可实现自动化、周期性地监管数据库中的特殊数据,并在发现特殊数据时,向用户及时反馈邮件,以便用户获知数据变更情况。
在本发明的一种具体实施方式中,邮件通知模块103,具体用于基于授权码和简单邮件传送协议将通知邮件发送至Windows系统下的邮件终端。
在本发明的一种具体实施方式中,数据读取模块101,具体用于利用 crontab命令定期获取目标数据表和历史数据表。
在本发明的一种具体实施方式中,邮件通知模块103,具体用于利用目标数据为邮件变量进行赋值,生成通知邮件;邮件变量对应邮件主题、邮件正文或邮件附件。
在本发明的一种具体实施方式中,当数据库用于存储设备订单数据时,目标数据表具体为目标设备订单表,历史数据表具体为历史设备订单表;数据读取模块101,具体用于定期获取数据库中的材料列表和订单列表;
利用材料列表和订单列表筛选出具有指定类型器件或指定类型器件组合的目标设备订单表;读取具有指定类型器件或指定类型器件组合的历史设备订单表。
在本发明的一种具体实施方式中,数据监测模块102,具体用于对比目标设备订单表和历史设备订单表,确定出数据库是否新增/删除特殊设备订单。
在本发明的一种具体实施方式中,邮件通知模块103,具体用于将特殊设备订单的订单号添加至特殊订单列表中;将特殊订单列表添加在通知邮件中。
实施例三:
相应于上面的方法实施例,本发明实施例还提供了一种数据变更通知设备,下文描述的一种数据变更通知设备与上文描述的一种数据变更通知方法可相互对应参照。
参见图5所示,该数据变更通知设备包括:
存储器D1,用于存储计算机程序;
处理器D2,用于执行计算机程序时实现上述方法实施例的数据变更通知方法的步骤。
具体的,请参考图6,为本实施例提供的一种数据变更通知设备的具体结构示意图,该数据变更通知设备可因配置或性能不同而产生比较大的差异,可以包括一个或一个以上处理器(central processing units,CPU)322(例如,一个或一个以上处理器)和存储器332,一个或一个以上存储应用程序342或数据 344的存储介质330(例如一个或一个以上海量存储设备)。其中,存储器332和存储介质330可以是短暂存储或持久存储。存储在存储介质330的程序可以包括一个或一个以上模块(图示没标出),每个模块可以包括对数据处理设备中的一系列指令操作。更进一步地,中央处理器322可以设置为与存储介质330通信,在数据变更通知设备301上执行存储介质330中的一系列指令操作。
数据变更通知设备301还可以包括一个或一个以上电源326,一个或一个以上有线或无线网络接口350,一个或一个以上输入输出接口358,和/或,一个或一个以上操作系统341。例如,Windows ServerTM,Mac OS XTM,UnixTM, LinuxTM,FreeBSDTM等。
上文所描述的数据变更通知方法中的步骤可以由数据变更通知设备的结构实现。
实施例四:
相应于上面的方法实施例,本发明实施例还提供了一种可读存储介质,下文描述的一种可读存储介质与上文描述的一种数据变更通知方法可相互对应参照。
一种可读存储介质,可读存储介质上存储有计算机程序,计算机程序被处理器执行时实现上述方法实施例的数据变更通知方法的步骤。
该可读存储介质具体可以为U盘、移动硬盘、只读存储器(Read-Only Memory,ROM)、随机存取存储器(Random Access Memory,RAM)、磁碟或者光盘等各种可存储程序代码的可读存储介质。
专业人员还可以进一步意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、计算机软件或者二者的结合来实现,为了清楚地说明硬件和软件的可互换性,在上述说明中已经按照功能一般性地描述了各示例的组成及步骤。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本发明的范围。
Claims (10)
1.一种数据变更通知方法,其特征在于,应用于linux系统中,包括:
定期获取数据库中指定类别数据或指定类别数据组合对应的目标数据表,以及与所述目标数据表对应的历史数据表;
对比所述目标数据表和所述历史数据表,确定所述数据库是否新增/删除目标数据;
如果是,则生成所述目标数据对应的通知邮件,并在发送所述通知邮件后利用所述目标数据表更新所述历史数据表。
2.根据权利要求1所述的数据变更通知方法,其特征在于,发送所述通知邮件,包括:
基于授权码和简单邮件传送协议将所述通知邮件发送至Windows系统下的邮件终端。
3.根据权利要求1所述的数据变更通知方法,其特征在于,所述定期获取数据库中指定类别数据或指定类别数据组合对应的目标数据表,以及与所述目标数据表对应的历史数据表,包括:
利用crontab命令定期获取所述目标数据表和所述历史数据表。
4.根据权利要求1所述的数据变更通知方法,其特征在于,所述生成目标数据对应的通知邮件,包括:
利用所述目标数据为邮件变量进行赋值,生成所述通知邮件;所述邮件变量对应邮件主题、邮件正文或邮件附件。
5.根据权利要求1所述的数据变更通知方法,其特征在于,当所述数据库用于存储设备订单数据时,所述目标数据表具体为目标设备订单表,所述历史数据表具体为历史设备订单表;定期获取数据库中指定类别数据或指定类别数据组合对应的目标数据表,以及与所述目标数据表对应的历史数据表,包括:
定期获取数据库中的材料列表和订单列表;
利用所述材料列表和所述订单列表筛选出具有指定类型器件或指定类型器件组合的所述目标设备订单表;
读取具有所述指定类型器件或所述指定类型器件组合的所述历史设备订单表。
6.根据权利要求5所述的数据变更通知方法,其特征在于,对比所述目标数据表和所述历史数据表,确定所述数据库是否新增/删除目标数据,包括:
对比所述目标设备订单表和所述历史设备订单表,确定出所述数据库是否新增/删除特殊设备订单。
7.根据权利要求6所述的数据变更通知方法,其特征在于,所述生成所述目标数据对应的通知邮件,包括:
将所述特殊设备订单的订单号添加至特殊订单列表中;
将所述特殊订单列表添加在所述通知邮件中。
8.一种数据变更通知装置,其特征在于,应用于linux系统中,包括:
数据读取模块,用于定期获取数据库中指定类别数据或指定类别数据组合对应的目标数据表,以及与所述目标数据表对应的历史数据表;
数据监测模块,用于对比所述目标数据表和所述历史数据表,确定所述数据库是否新增/删除目标数据;
邮件通知模块,用于如果所述数据库新增/删除所述目标数据,则生成所述目标数据对应的通知邮件,并在发送所述通知邮件后利用所述目标数据表更新所述历史数据表。
9.一种数据变更通知设备,其特征在于,包括:
存储器,用于存储计算机程序;
处理器,用于执行所述计算机程序时实现如权利要求1至7任一项所述数据变更通知方法的步骤。
10.一种可读存储介质,其特征在于,所述可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现如权利要求1至7任一项所述数据变更通知方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201911367788.9A CN111162995A (zh) | 2019-12-26 | 2019-12-26 | 一种数据变更通知方法、装置、设备及可读存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201911367788.9A CN111162995A (zh) | 2019-12-26 | 2019-12-26 | 一种数据变更通知方法、装置、设备及可读存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN111162995A true CN111162995A (zh) | 2020-05-15 |
Family
ID=70558470
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201911367788.9A Pending CN111162995A (zh) | 2019-12-26 | 2019-12-26 | 一种数据变更通知方法、装置、设备及可读存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN111162995A (zh) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113807923A (zh) * | 2021-09-23 | 2021-12-17 | 杭州右文网络科技有限公司 | 一种订单处理方法、装置、电子设备及可读存储介质 |
CN114118956A (zh) * | 2021-11-22 | 2022-03-01 | 城云科技(中国)有限公司 | 数据新增邮件提醒方法、装置及应用 |
CN114596952A (zh) * | 2022-03-22 | 2022-06-07 | 武汉联影生命科学仪器有限公司 | 配置监控方法、装置、磁共振成像系统和存储介质 |
Citations (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6477548B1 (en) * | 1998-09-30 | 2002-11-05 | Casio Computer Co., Ltd. | Server computer capable of automatically notifying updated database content to client computer, and program storage medium |
CN1673972A (zh) * | 2004-08-04 | 2005-09-28 | 上海宝信软件股份有限公司 | 数据库表更新的动态监控系统及方法 |
CN1759411A (zh) * | 2003-01-22 | 2006-04-12 | 国际商业机器公司 | 用于使项目事件与个人日历和日程安排客户机集成的系统和方法 |
JP2015035096A (ja) * | 2013-08-08 | 2015-02-19 | シャープ株式会社 | 情報管理システム、情報管理方法及びプログラム |
JP2015170076A (ja) * | 2014-03-06 | 2015-09-28 | 株式会社東芝 | データベースシステム |
CN107784043A (zh) * | 2016-08-31 | 2018-03-09 | 北京京东尚科信息技术有限公司 | 数据仓库数据表的监控方法、装置及系统 |
EP3407527A1 (en) * | 2016-01-18 | 2018-11-28 | Alibaba Group Holding Limited | Method, device, and system for data synchronization |
CN109213792A (zh) * | 2018-07-06 | 2019-01-15 | 武汉斗鱼网络科技有限公司 | 数据处理的方法、服务端、客户端、装置及可读存储介质 |
CN109284312A (zh) * | 2018-08-27 | 2019-01-29 | 山东威尔数据股份有限公司 | 一种异构数据库变更实时通知方法 |
CN110515807A (zh) * | 2019-09-02 | 2019-11-29 | 北京启迪区块链科技发展有限公司 | 一种数据库表监控方法、装置、设备及存储介质 |
-
2019
- 2019-12-26 CN CN201911367788.9A patent/CN111162995A/zh active Pending
Patent Citations (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6477548B1 (en) * | 1998-09-30 | 2002-11-05 | Casio Computer Co., Ltd. | Server computer capable of automatically notifying updated database content to client computer, and program storage medium |
CN1759411A (zh) * | 2003-01-22 | 2006-04-12 | 国际商业机器公司 | 用于使项目事件与个人日历和日程安排客户机集成的系统和方法 |
CN1673972A (zh) * | 2004-08-04 | 2005-09-28 | 上海宝信软件股份有限公司 | 数据库表更新的动态监控系统及方法 |
JP2015035096A (ja) * | 2013-08-08 | 2015-02-19 | シャープ株式会社 | 情報管理システム、情報管理方法及びプログラム |
JP2015170076A (ja) * | 2014-03-06 | 2015-09-28 | 株式会社東芝 | データベースシステム |
EP3407527A1 (en) * | 2016-01-18 | 2018-11-28 | Alibaba Group Holding Limited | Method, device, and system for data synchronization |
CN107784043A (zh) * | 2016-08-31 | 2018-03-09 | 北京京东尚科信息技术有限公司 | 数据仓库数据表的监控方法、装置及系统 |
CN109213792A (zh) * | 2018-07-06 | 2019-01-15 | 武汉斗鱼网络科技有限公司 | 数据处理的方法、服务端、客户端、装置及可读存储介质 |
CN109284312A (zh) * | 2018-08-27 | 2019-01-29 | 山东威尔数据股份有限公司 | 一种异构数据库变更实时通知方法 |
CN110515807A (zh) * | 2019-09-02 | 2019-11-29 | 北京启迪区块链科技发展有限公司 | 一种数据库表监控方法、装置、设备及存储介质 |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113807923A (zh) * | 2021-09-23 | 2021-12-17 | 杭州右文网络科技有限公司 | 一种订单处理方法、装置、电子设备及可读存储介质 |
CN113807923B (zh) * | 2021-09-23 | 2024-02-09 | 杭州右文网络科技有限公司 | 一种订单处理方法、装置、电子设备及可读存储介质 |
CN114118956A (zh) * | 2021-11-22 | 2022-03-01 | 城云科技(中国)有限公司 | 数据新增邮件提醒方法、装置及应用 |
CN114596952A (zh) * | 2022-03-22 | 2022-06-07 | 武汉联影生命科学仪器有限公司 | 配置监控方法、装置、磁共振成像系统和存储介质 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8788597B2 (en) | Recalling spam email or viruses from inboxes | |
US7921459B2 (en) | System and method for managing security events on a network | |
CN111162995A (zh) | 一种数据变更通知方法、装置、设备及可读存储介质 | |
CA2476108C (en) | Hierarchical org-chart based email mailing list maintenance | |
US7970834B2 (en) | Method and program product for tracking a file attachment in an e-mail | |
US6505214B1 (en) | Selective information synchronization based on implicit user designation | |
US8195757B2 (en) | Method, apparatus and computer program for controlling retention of publications | |
JP5406914B2 (ja) | 電子メールメッセージの送信者または受信者に関連する送信前データのキャッシュおよび公開 | |
US6617969B2 (en) | Event notification system | |
US9667585B2 (en) | Central people lists accessible by multiple applications | |
US8566406B2 (en) | Filtering of electronic mail messages destined for an internal network | |
US5978566A (en) | Client side deferred actions within multiple MAPI profiles | |
US6732157B1 (en) | Comprehensive anti-spam system, method, and computer program product for filtering unwanted e-mail messages | |
US8073822B2 (en) | Method and apparatus for managing electronic messages | |
US8327445B2 (en) | Time travelling email messages after delivery | |
US6654751B1 (en) | Method and apparatus for a virus information patrol | |
US10223369B2 (en) | Processing electronic messages | |
JP2007172624A (ja) | 電子メール添付ファイルのバージョン管理を提供する方法及びシステム | |
US9450902B2 (en) | Method and system for marking email threads | |
US20040135816A1 (en) | Method and system for identifying message recipients | |
US20050060281A1 (en) | Rule-based content management system | |
US20030018643A1 (en) | VIGIP006 - collaborative resolution and tracking of detected events | |
US20100057765A1 (en) | Email attachment storage method and system | |
US9515973B1 (en) | System and method for analyzing and filtering journaled electronic mail | |
US7979492B2 (en) | Time decayed dynamic e-mail address |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination |