1. Technical Field
The present disclosure relates to systems and methods to minimize database queries to improve computer system efficiency and operation.
2. Introduction
Many organizations have data stored in different locations and in different databases. Different data may be stored in these different databases. The databases may be the central repositories for the respective different data types used across an organization. As such, many or all of the organization's locations may need access to and to run queries against these databases. In addition, the data required for a task may be stored in disparate ones of the databases. This data must be retrieved from the different databases and merged. To search and retrieve data from these databases requires many different database queries. Moreover even once the data is found, the queries may continue to run as they are structured to search all the available data fields in the databases for the requested data. These scenarios result in the system running slowly, and even becoming overloaded and failing.
A method comprising receiving via a user application claim information including item identifying information; querying an item database to locate item information corresponding to the item identify information; merging the item identifying information with the item information from the item database to obtain first merged data; temporarily storing the merged data; determining an item number from the merged information; querying an invoice database to retrieve invoice information corresponding to the item number; merging the invoice information with the first merged data to obtain second merged data; and storing the second merged data as a single record for the item in a claims database.
A method comprising receiving via a user application claim information including item identifying information, an impact and a quantity; automatically creating a time/date stamp for the claim information; automatically determining a location for the claim; creating a claim record in a claim database, the claim record including the item identifying information, the impact, the quantity, the time/date stamp and the location; querying an item database to locate item information corresponding to the item identity information; merging the claim record with the item information from the item database to obtain first merged data; determining an item number from the merged data; querying an invoice database to locate invoice information corresponding to the item number; retrieving the invoice information from the invoice database; notifying store when the invoice information is not found; merging the invoice information with the first merged data into one data record; storing the data record a database.
A system, comprising an item database storing an item record including an item, item description, item number; an invoice database storing an invoice record including item number, quantity, price, date shipped, invoice number, and trailer ID; a store computer having a store user application; distribution center computer having a user application; a server; and the claims database, the item database, the invoice database, the store computer, the distribution center computer, and the server connected to a network, the server: receiving via a user application claim information including item identifying information; querying the item database to locate item information corresponding to the item identify information; merging the item identifying information with the item information from the item database to obtain first merged data; temporarily storing the merged data; determining an item number from the merged information; querying the invoice database to retrieve invoice information corresponding to the item number; merging the invoice information with the first merged data to obtain second merged data; and storing the second merged data as a single record for the item in a claims database.
Additional features and advantages of the disclosure will be set forth in the description which follows, and in part will be obvious from the description, or can be learned by practice of the herein disclosed principles. The features and advantages of the disclosure can be realized and obtained by means of the instruments and combinations particularly pointed out in the appended claims. These and other features of the disclosure will become more fully apparent from the following description and appended claims, or can be learned by the practice of the principles set forth herein.
Various configurations and embodiments of the disclosure are described in detail below. While specific implementations are described, it should be understood that this is done for illustration purposes only. Other components and configurations may be used without parting from the spirit and scope of the disclosure.
The disclosed systems, methods, and computer-readable storage mediums improve the efficiency of computers and database systems. Embodiments of the invention improve the operation of the computer system by minimizing the number of queries used to locate the data distributed across different databases. Remaining information required to process a task, such as a claim, may be automatically retrieved and validated. In addition, the queries may cease as soon as the desired data is located. These improvements reduce the operating load on the system and improve the speed and efficiency of data retrieval. In addition, the queries may be scheduled to run at a selected time, for example in the evening or overnight when processing loads are typically lighter, thus improving the operation of the system at other times. Embodiments of the invention are described in more detail below in the context of retail stores, but may be used in any environment where data is stored or distributed in different databases.
An item database 114 may also be connected to the network 110. The item database 114 may be a central database used by all of the stores and distribution centers for a geographic area, such as North America, Asia, a group of states and the like. The item database 114 stores information regarding the items available for sale at the retail stores. The item database 114 may store, for each item, a database record. The database record may include an item number for the item, a UPC code, a PLU code, or other item identifying information. This information may be stored in one or more tables in the database 114.
An invoice database 116 may also be connected to the network 110. The invoice database 116 may include a database record for each order the retail stores place to the distribution centers. This information may be stored in one or more tables in the database 116. The invoice database 116 may be a central database used by all of the stores and distribution centers.
A claim processing server 120 may also be connected to the network 110. The claim processing server 120 may communication with each of the store computers 102-106, the item database 114, the invoice database 116, and the distribution computer system 112 via the network 110. A claim processing database 122 for storing information about claims may also be connected to the network 110.
In an exemplary embodiment, retail stores may use the claim processing server 120 to make a claim against a distribution center 112. Information about the claim may be entered using the store computer 102 via an application and user interface. The claims may be stored in the claims processing database 122 for processing at a later time or for batch processing, for example during off-peak hours.
The claim processing server 120 may use the input information to process the claim and validate the claim data. Using the claim information entered via the application, the claim processing server 120 may query the item database 114 and the invoice database 116 to retrieve to retrieve additional information from the databases regarding the claim and the items. The information from the different databases may be merged together into a single database record which is then validated and stored in the claim processing database 122. The information may also be checked and its accuracy verified by the claim processing server 120. The applications running at the distribution center computer 112 may then interact with the claim processing server 120 to identify the claims that have been validated.
The system may automatically create a time/date stamp for the claim when the data for the claim is entered. In addition, the store location may also be automatically determined, for example using geolocation data. A claim record is created for processing and stored in the claims database 122. All unprocessed claims may be pulled and batched processed, step 202.
Turning to step 204, the identifying information is used to query the item database 114 to located the record for the item and retrieve additional information about the item. The query may run in a cascading fashion to match the possible different types of identifying information with a data field in database 114 until the item is located in the item database 114. Once the item is located in the item database 114, the query process stops. In one example of the cascading process, the identifying information that is collected via the store computer is the UPC code. However, as noted there are many different type of UPC codes, as well as other codes that may be collected. The system may not know that the identifying information is an item UPC code. The item database 114 is queried to determine if there is a record for an item that matches the collected identifying information. The first data field queried may be the field for the item number. The data field for item numbers in the database are matched against the scanned UPC code. As the UPC is not an item number, there would not be a match. The process may then cascade through other data fields in the item database 114 and try to match the UPC with a data field. A match should be found when the UPC data field is queried and the process may go into a temporary hold.
If the UPC submitted cannot be directly matched with a UPC from the Item File, then a sub-process shown in
Returning to
Per step 206, 210, if the item is found in the item database 114, the information from the item data base is blended with the information entered at the store computer. This merges the fields from item file and what was submitted by the user into one record for each item. The blended record may include what was claimed, how many items/cases from the claim processing system 120 and the item, item description, item number and other item information from the item database 114. This blended record may be stored temporarily for later use.
The claims processing system 120 in step 212 queries the invoice database 116 to locate invoice information associated with the item. The item number may be retrieved from the blended record from step 210. The item number may then be used to locate a matching record in the invoice database 116. Even if the item number was not originally entered by the user, such as in the case above where the UPC was scanned, the item number may be used as the key to search the invoice database 116. The invoice database 116 may be another database at a different location from the item database 114. In an exemplary embodiment, two tables in the invoice database 116 may be queried and concatenated. One table may store information regarding where the item was shipped, where was the item received from, when was it sent, etc. A second table may be a line table including fields for the item numbers, quantity, price, date shipped, invoice number, trailer ID, and the like.
In a further embodiment, a dynamic process executes to determine the invoice dates for querying in the invoice database 116. If the store is located in Alaska or Hawaii, the invoice search date may populate for 17 days prior to the date the record was created. This allows for added transit time for Alaska and Hawaii freight. All other stores' invoice search date may be 5 days prior to the date the record was created. Other timeframes may also be used depending on the circumstances.
Using the dynamic query, each individual record is searched against the invoice database 116 searching between the invoice search date calculated and the date the record was created. It also queries by the store which created the record and the item number which was previously identified when blending with the item file. The timeframe may be set to a predetermined time to assist in identify supply chain failures. If the missing items are not noticed within a specified time frame, it is unlikely that the issue resulted from a supply chain failure.
If no invoice within the timeframe is found, the claim may be held and checked again later to account for any time for processing invoices and for invoice database 116 to be updated. If the a matching invoice is not found, the record will not be marked as processed and another attempt to locate the invoice information will be made the next day for a selected number of days, here three days, steps 222, 226. If a matching invoice is not found after checking for the selected number of days, the record is marked as processed, and a “Not Shipped” indicator may be checked, step 224.
For those claims where an invoice is located, the invoice information located in step 212 is blended with the one data record for the item from step 210, resulting in a single record for the item. Invoice information and records may be summarized then sorted, step 216. The system may sums the invoice lines for each day shipped. It then takes the maximum shipment (by day) and attaches all of the other pertinent invoice information. It is then marked as processed, merged with all of the other records, and updated into the claims database. The records are marked as processed, step 218. A user at the distribution center may log in to the system and request the claims against the distribution center. The system may retrieve those records marked as processed from the claims database 122. Those records may be shown on a dashboard on the distribution center computer 112.
With reference
The system bus 410 may be any of several types of bus structures including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of bus architectures. A basic input/output (BIOS) stored in ROM 440 or the like, may provide the basic routine that helps to transfer information between elements within the computing device 400, such as during start-up. The computing device 400 further includes storage devices 460 such as a hard disk drive, a magnetic disk drive, an optical disk drive, tape drive or the like. The storage device 460 can include software modules 462, 464, 466 for controlling the processor 420. Other hardware or software modules are contemplated. The storage device 460 is connected to the system bus 410 by a drive interface. The drives and the associated computer-readable storage media provide nonvolatile storage of computer-readable instructions, data structures, program modules and other data for the computing device 400. In one aspect, a hardware module that performs a particular function includes the software component stored in a tangible computer-readable storage medium in connection with the necessary hardware components, such as the processor 420, bus 410, display 470, and so forth, to carry out the function. In another aspect, the system can use a processor and computer-readable storage medium to store instructions which, when executed by the processor, cause the processor to perform a method or other specific actions. The basic components and appropriate variations are contemplated depending on the type of device, such as whether the device 400 is a small, handheld computing device, a desktop computer, or a computer server.
Although the exemplary embodiment described herein employs the hard disk 460, other types of computer-readable media which can store data that are accessible by a computer, such as magnetic cassettes, flash memory cards, digital versatile disks, cartridges, random access memories (RAMs) 450, and read only memory (ROM) 440, may also be used in the exemplary operating environment. Tangible computer-readable storage media, computer-readable storage devices, or computer-readable memory devices, expressly exclude media such as transitory waves, energy, carrier signals, electromagnetic waves, and signals per se.
To enable user interaction with the computing device 400, an input device 490 represents any number of input mechanisms, such as a microphone for speech, a touch-sensitive screen for gesture or graphical input, keyboard, mouse, motion input, speech and so forth. An output device 470 can also be one or more of a number of output mechanisms known to those of skill in the art. In some instances, multimodal systems enable a user to provide multiple types of input to communicate with the computing device 400. The communications interface 480 generally governs and manages the user input and system output. There is no restriction on operating on any particular hardware arrangement and therefore the basic features here may easily be substituted for improved hardware or firmware arrangements as they are developed.
The various embodiments described above are provided by way of illustration only and should not be construed to limit the scope of the disclosure. Various modifications and changes may be made to the principles described herein without following the example embodiments and applications illustrated and described herein, and without departing from the spirit and scope of the disclosure.
Number | Name | Date | Kind |
---|---|---|---|
5383112 | Clark | Jan 1995 | A |
5929421 | Cherry et al. | Jul 1999 | A |
6292784 | Martin et al. | Sep 2001 | B1 |
6826557 | Carter | Nov 2004 | B1 |
7711612 | Farias | May 2010 | B1 |
8355947 | Quinlan et al. | Jan 2013 | B2 |
20010021929 | Lin | Sep 2001 | A1 |
20020184121 | Sijacic et al. | Dec 2002 | A1 |
20030074377 | Gupta et al. | Apr 2003 | A1 |
20030130945 | Force | Jul 2003 | A1 |
20040019567 | Herceg et al. | Jan 2004 | A1 |
20050289129 | Schmitt | Dec 2005 | A1 |
20060190380 | Force | Aug 2006 | A1 |
20070011041 | Bourne | Jan 2007 | A1 |
20070203876 | Hoopes et al. | Aug 2007 | A1 |
20070239769 | Fazal | Oct 2007 | A1 |
20080133478 | Weiler et al. | Jun 2008 | A1 |
20080172312 | Synesiou | Jul 2008 | A1 |
20090018933 | Drazan et al. | Jan 2009 | A1 |
20090043594 | Tseng | Feb 2009 | A1 |
20090228345 | Ford | Sep 2009 | A1 |
20110179048 | Satlow | Jul 2011 | A1 |
20120123950 | Gventer | May 2012 | A1 |
20140149269 | Kantarjiev | May 2014 | A1 |
20140374478 | Dearing | Dec 2014 | A1 |
20150144689 | Cancro et al. | May 2015 | A1 |
20160261567 | Baskaran | Sep 2016 | A1 |
Number | Date | Country |
---|---|---|
2012040820 | Apr 2012 | WO |
Entry |
---|
“Processing Invoice Claims”, Sap.com, accessed Dec. 19, 2016 (3 pp). |
“Oracle Accounts Receivable Deductions Settlement User Guide”, Oracle.com, accessed Dec. 19, 2016 (32 pp). |
International Search Report and Written Opinion issued in corresponding International Application No. PCT/US2017/065380 dated Feb. 9, 2018 (12 pp). |
Number | Date | Country | |
---|---|---|---|
20180189845 A1 | Jul 2018 | US |
Number | Date | Country | |
---|---|---|---|
62440629 | Dec 2016 | US |