WO2001084372A1 - Browser-based database-access engine apparatus and method - Google Patents

Browser-based database-access engine apparatus and method Download PDF

Info

Publication number
WO2001084372A1
WO2001084372A1 PCT/US2001/013525 US0113525W WO0184372A1 WO 2001084372 A1 WO2001084372 A1 WO 2001084372A1 US 0113525 W US0113525 W US 0113525W WO 0184372 A1 WO0184372 A1 WO 0184372A1
Authority
WO
WIPO (PCT)
Prior art keywords
database
data
user
service module
web
Prior art date
Application number
PCT/US2001/013525
Other languages
French (fr)
Inventor
Steven D. Lloyd
Original Assignee
Inshift Technologies, Llc
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Inshift Technologies, Llc filed Critical Inshift Technologies, Llc
Priority to AU2001259180A priority Critical patent/AU2001259180A1/en
Publication of WO2001084372A1 publication Critical patent/WO2001084372A1/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/958Organisation or management of web site content, e.g. publishing, maintaining pages or automatic linking
    • G06F16/972Access to data in other repository systems, e.g. legacy data or dynamic Web page generation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/958Organisation or management of web site content, e.g. publishing, maintaining pages or automatic linking
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99931Database or file accessing
    • Y10S707/99932Access augmentation or optimizing
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99931Database or file accessing
    • Y10S707/99933Query processing, i.e. searching
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10TECHNICAL SUBJECTS COVERED BY FORMER USPC
    • Y10STECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y10S707/00Data processing: database and file management or data structures
    • Y10S707/99931Database or file accessing
    • Y10S707/99933Query processing, i.e. searching
    • Y10S707/99934Query formulation, input preparation, or translation

Definitions

  • This invention relates to computer software and, more particularly, to novel systems and methods for accessing databases through computer networks including, without limitation, local area networks, wide area networks, and global networks.
  • Databases are very useful and powerful. Likewise, database management systems and engines for accessing databases abound. Unfortunately, many database management systems require a cadre of management information systems personnel and often programmers and computer gurus to make the data useful and available to users. Of course, these human resources do not come without a cost. In some cases, users may need training to work with database query languages or graphical user interfaces. In effect, without the correct skilled personnel or necessary expertise, data becomes virtually useless to the users thereof.
  • the ability to manage and manipulate the data of a database, including the end user data and the schema of a database, through a network, such as the Internet, is very limited. What is needed is a way for users to have access and control of the data, including the end user data and the schema of a database, irrespective of the type or origin of the database, through a network, such as the Internet.
  • a method and apparatus are disclosed in one embodiment of the present invention as including a computer having a browser, having a communication link established with a web server, and making a request thereto.
  • the web server upon receiving the request, may then forward the request to the service module of the present invention.
  • the service module may be located on the same computer as the web server, or be hosted by an application server, in certain embodiments. According to the level of access afforded to a user, a user may have the ability to view data from the database or, if more authority is granted, a user may actually have the ability to modify the data or schema of a database.
  • a user may be able to manage a database remotely, using nothing more than a simple browser application.
  • the database may be located on a server located remotely from the web server, connected by the Internet, or may be located on the same computer as the web server.
  • a browser, web server, service module, and database may all be hosted on the same computer.
  • the service module of the present invention may be configured to translate requests made to a web server into a database language necessary for communication with a database.
  • the service module may be configured to communicate with any SQL compliant database. Once a request is made to the service module and authority is granted to a user, the service module may then retrieve or change information contained within a database.
  • Such information may include data, tables, forms, queries, reports, web pages, user profiles, or other data.
  • web pages may be stored at one location in a database while data stored at another location may supply content to the web pages.
  • the present invention provides an efficient apparatus and method for maintaining and updating web sites by dynamically retrieving data each time a web page is called by a browser.
  • the service module may also parse any data retrieved from the database and execute any logic found therein.
  • Special tags may be included within the HTML coding of web pages, which may not be recognized by a typical browser, but may be understood by the service module of the present invention and may be used to execute instructions. For example, conditional statements may be included to forward a user to distinct web pages depending on the input entered by a user. Alternatively, an instruction programmed within the source code of a web page may be executed to actually retrieve data from a database to be inserted into the web page. Once the data is retrieved and any logic found therein is executed, the result may be subsequently forwarded to the web server and on to the browser for viewing by a user.
  • the service module may effectively act as an interface between a web server and a database.
  • Figure 1 is a schematic block diagram of one architecture for a hardware suite suitable for implementing an apparatus in accordance with the present invention
  • Figure 2 is a schematic block diagram illustrating various possible implementations of the present invention
  • Figure 3 is a schematic block diagram of the service module, startup configuration data, and database records contained within memory in accordance with the invention;
  • Figure 4 is a schematic block diagram of various functions performed by the service module of the present invention.
  • Figure 5 is a schematic block diagram of one embodiment of database records accessed by the service module of the present invention.
  • Figure 6 is a schematic block diagram illustrating the flow of communication performed by the present invention.
  • Figure 7 is a flow chart showing the sequence of steps performed by the present invention when an anonymous request is made.
  • Figure 8 is a flow chart showing the sequence of steps performed by the present invention when a secure request is made.
  • an apparatus 10 of one presently preferred embodiment of the present invention may include a node 11 (client 11, computer 11) containing a processor 12 or CPU 12.
  • the CPU 12 may be operably connected to a memory device 14.
  • a memory device 14 may include one or more devices such as a hard drive 16 or non- volatile storage device 16, a read-only memory 18 (ROM), and a random-access (and usually volatile) memory 20 (RAM).
  • the apparatus 10 may include an input device 22 for receiving inputs from a user or another device.
  • an output device 24 may be provided within the node 11, or accessible within the apparatus 10.
  • a network card 26
  • interface card or port 28 may be provided for connecting to outside devices, such as the network 30.
  • a bus 32 may operably interconnect the processor 12, memory devices 14, input devices 22, output devices 24, network card 26 and port 28.
  • the bus 32 may be thought of as a data carrier.
  • the bus 32 may be embodied in numerous configurations. Wire, fiber optic line, wireless electromagnetic communications by visible light, mfrared, and radio frequencies may likewise be implemented as appropriate for the bus 32 and the network 30.
  • Input devices 22 may include one or more physical embodiments.
  • a keyboard 34 may be used for interaction with the user, as may a mouse 36.
  • a touch screen 38, a telephone 39, or simply a telephone line 39, may be used for communication with other devices, with a user, or the like.
  • a scanner 40 may be used to receive graphical inputs which may or may not be translated to other character formats.
  • a hard drive 41 or other memory device 14 may be used as an input device whether resident within the node 11 or some other node 52 (e.g., 52a, 52b, etc.) on the network 30, or from another network 50.
  • Output devices 24 may likewise include one or more physical hardware units.
  • the port 28 may be used to accept inputs and send outputs from the node 11.
  • a monitor 42 may provide outputs to a user for feedback during a process, or for assisting two-way communication between the processor 12 and a user.
  • a printer 44 or a hard drive 46 may be used for outputting information as output devices 24.
  • a network 30 to which a node 11 connects may, in turn, be connected through a router 48 to another network 50.
  • two nodes 11 , 52 may be on a network 30, adjoining networks 30, 50, or may be separated by multiple routers 48 and multiple networks 50 as individual nodes 11, 52 on an internetwork.
  • the individual nodes 52 may have various communication capabilities. In certain presently preferred embodiments of the present invention, a minimum of logical capability may be available in any node 52. Note that any of the individual nodes 52 may be referred to, as may all together, as a node 52 or nodes 52.
  • a network 30 may include one or more servers 54. Servers may be used to manage, store, communicate, transfer, access, update, and the like, any number of files for a network
  • a server 54 may be accessed by all nodes 11, 52 on a network 30.
  • a node 11 may need to communicate over a network 30 with a server 54, a router 48, or nodes 52. Similarly, a node 11 may need to communicate over another network (50) in an internetwork connection with some remote node 52. Likewise, individual components of the apparatus 10 may need to communicate data with one another. A communication link may exist, in general, between any pair of devices or components.
  • nodes 52 any one or all of the nodes 48, 52, 54, 56, 58, 60, 62, 11. Thus, any one of the nodes 52 may include any or all of the component parts illustrated in the node 11.
  • the node 60 hosts the software and data structures required for providing directory services to the nodes 52 in the network 30 and may do so for other nodes 52 in other networks 50.
  • the node 60 may typically be a server 54 in a network. However, it may be installed in any node 52.
  • a node 52 may typically include a network card 26 for connecting to the network 30, a processor 12 for processing software commands, a memory device 20 for operational memory as well as a non- volatile storage device 16 such as a hard drive 16.
  • an input device 22 and an output device 24 are provided for user interaction with the node 60.
  • any number of workstation nodes 58, 62 may exist in a network 30, within some practical limit.
  • Any network 30, 50 may be part of, and connect to the Internet 76.
  • a user may be connected to the Internet 76 through an Internet service provider 74a.
  • the user 72 may be any computer system, such as system 11 in Figure 1 , having a browser 86a.
  • the user 72 may be configured to communicate with a web server 68a that is configured to provide web pages that are stored in the memory of the web server 68a and are viewable by a user 72.
  • a service module 64a may also be located in the memory of the web server by 68a and may comprise executable and operational data structures configured to be processed in the processor of the web server 68a.
  • the service module 64a may be configured to retrieve the web page data from a location in a database 80a on a remotely located database server, such as server 78a.
  • the service module 64a may actually process programming embedded within the HTML coding of web pages located on the database server 78a.
  • the programming may comprise executable logic that may dynamically retrieve data within another location in the database 80a to provide content to the web page.
  • Such executable logic may be coded in a language understandable by the service module 64a of the present invention.
  • the logic may be embedded within special tags contained in the HTML-encoded page. These special tags are typically configured to be ignored by the typical browser, but these special tags configured to be understood and executed by the service module 64a of the present invention.
  • the executable logic may comprise conditional statements that may be executed in response to user input.
  • coding may be included within a web page to process conditional "if statements, such as when receiving a password from a user.
  • the coding within the web page may be configured to deny a user access and/or may forward the user to another specific web page.
  • input by a user through the browser 86a may be processed by the service module 64a to modify the data and/or even the schema of the database 80a.
  • a user 72, web server 68a, and database server 78a may be connected to the Internet 76 to function in accordance with the invention while being physically located at geographically distant locations around the Earth.
  • a user need not be a single user 72, but may actually be any user connected to the Internet 76, such as a plurality of users 70a-c connected by a local area network (LAN) 86.
  • LAN local area network
  • Any user 70c, such as users 70a, 70b, 70c, and 72, having a browser 86b, such as browsers 86a, 86b, and 86c, with Internet access may access the web server 68a and the database 80a.
  • the service module 64b may actually be located on an ASP (application service provider) server 66. Therefore, a web server 68b may forward a request to a service module 64b located on ASP server 66. hi turn, the service module 64b may retrieve or modify data and/or schema in a database 80a on a server 78a.
  • the application server 66 may be configured to provide to a plurality of businesses or individuals the services of the service module 64b. Thus, in the depicted configuration, any need to install the service module 64b on one or more web server(s) may be avoided.
  • the service module 64c, database 80b, and browser 86c may all be located on a computer of a single user 70d.
  • a service module 64d and database 80c may both be located on the web server 68c and may be accessed by any user 72 and/or group of users 70a-c connected to the Internet.
  • a service module 64e may be located on an enterprise server 84 connected to a database server 78b.
  • a plurality of workstations 82a, 82b, each having thereon a browser 84d and each in operable communication with the enterprise server 84, may access the database server 78b through the server 84.
  • a memory device 14 in a computer 11 may include a service module 64 comprising a table management module 90, a forms management module 92, a query management module 94, a report management module 96, a web management module 98, a user management module 99, and other modules 100.
  • a memory device 14 may also store startup and configuration data 102 used to initiate the service module 64. Additionally, a memory device 14 may actually store a database 80, which may comprise records or tables populated with data.
  • a database stores information within some type of a schema, such as records or tables.
  • a table management module 90 may be used in accordance with the present invention to manage the schema, typically embodied as tables, of one or more databases(s). Such tables will be explained in further detail in the description of Figure 4.
  • the table management module 90 may enable a user and/or several users to alter the schema or structure of a database, if desired.
  • Forms provide a convenient and graphical way for a user to populate a database with data. Data entry may be simplified by providing a user with graphical boxes or areas where data may be input. Consequently, a forms management module 92 may be included with the present invention to design and manage forms to be used for data input.
  • the present invention may include a query management module 94 to manage any queries of a database.
  • a report management module 98 may be included in the service module 64 to manage such database reports.
  • a web management module 98 may be included with the present invention wherein web pages may be more easily managed.
  • the web management module 98 may be used to create web pages whose content may be dynamically updated as data in the database changes. This ability to dynamically update the content of web pages may provide a tremendous time savings by eliminating much of the programming required to update content in static web pages.
  • a user management module 99 may also be included with the present invention to control users' access to a database and to control the level of access granted thereto. For example, some users may be granted access only to view data, whereas other users may be granted privileges to access and modify not only the data of a database, but also the schema. The level of access and privileges may be customized according to the individual user. Such a feature may provide a needed level of security to control access to a database granted to some users while still providing an increased level of access to other users.
  • other modules 100 may be included in the service module 64 as needed to provide additional functions.
  • a service module 64 of the present invention may include a table management module 90 providing the ability to alter the schema or structure of a database. For example, a user may be able to add 104, edit 106, or delete 108 tables according to the configuration required of a database. Likewise, a user may be able to list 110 existing tables within a database or view 112 the data contents of a table. Accordingly, other functions 114 or tools 114 that may provide a user the ability to modify, view, or work with tables in a database may be provided in the table management module 90 of the present invention.
  • the table management module 90 may allow a user to populate a table with data. For example, a user may add 116, edit 118, or delete 120 fields within each table. Likewise a user may list 122, search 126, or view 124 data within a table. Other tools 126 or functions 126 may also be provided as needed to work with the data in a database.
  • the forms management module 92 may be included within the service module 64 of the present invention to enable a user to design and work with forms. A user may choose to design a form or actually use the form to input data to a database. For example, a user may choose to add 128, edit 130, or delete 132 a form. In addition, a user may choose to list 134 existing forms or view 136 a particular form. Once a form is created, it may then be used 138 to add 120, edit 118, or delete 116 data.
  • a query management module 94 may be included with the present invention to create and execute queries.
  • a query may be added 128, edited 130, or deleted 132.
  • a query management module 94 may be used to list 146 queries or view a particular query 148. Once a query is created, it may be executed 150 in order to search a database based on chosen criteria.
  • a report management module 96 may also be included in the service module 64 of the present invention to create and run reports. Like the previous modules discussed, reports may be added 152, edited 154, or deleted 156. In addition, reports that have been created may be listed 158 or a particular report may be viewed 160. Once a report has been created, it may be run 162 whereby the data is actually retrieved from a database to populate the report with data.
  • a web management module 98 may be included in the present invention to allow a user to create web pages. The present invention offers the advantage of allowing the design of web pages that may be dynamically updated, thus saving time that might be lost reprogramming static pages.
  • Logic may be added within an HTML encoded web page that is understandable by the service module 64 that will actually retrieve the current data contents of a location in a database to provide content to a web page.
  • a web page may be updated simply by changing the data in the database to which it refers, addition prograriiming logic may be embedded in the HTML coding that may be executed in accordance with the present invention.
  • the web management module 98 may provide a user the ability to add 164, edit 166, or delete 168 web pages.
  • a user may be able to list 170 existing web pages or view 172 a particular web page.
  • the service module 64 may also include a user management module 99 provided to manage levels of access granted to users registered therein. In certain embodiments, any anonymous user may be allowed to view data, while only certain users may be granted the authority to actually alter the data or schema of a database.
  • the user management module 99 may allow the adding 176 or deleting 180 of a user by a user with administrative authority. Likewise, a user profile may be edited 178 such as when changing the level of access or authority of a particular user. Additionally the module 99 may allow a user or administrator to view a list of registered users or view the profile of a particular user.
  • a user may actually gain access to a database by entering a particular user ID and password.
  • the present invention may make use of other modules as additional functions are needed.
  • the criteria may be added, edited, deleted, listed, viewed, or processed in accordance with the invention.
  • a database 80 contained in memory 14 may be comprised of a plurality of tables 190, 192, 194. Some of the tables may contain data while other tables may contain schema 200 information or indices 202 of the other tables 190, 192, 194.
  • a table 190 may contain web page templates 196, while another table 192 may contain the content 198 or data 198 used in the web page templates 196.
  • coding embedded with the web pages 196 may contain instructions to pull data 198 or content 198 from the table 192.
  • HTML web page source code which is typically coded with "special tags.” Such special tags may be used in accordance with the present invention to interact with executable and often embedded logic. Such logic may either be instructions to retrieve data as previously stated or may contain other executable instructions.
  • this privilege may be reserved for authorized users only.
  • FIG. 6 a flow chart showing the flow of communication in accordance with the present invention is illustrated.
  • a browser 86 having a communication link established with a web server 68, may make a request therefrom. This request may subsequently be forwarded to the service module 64 of the present invention.
  • a user may be granted the ability to view 206 or use 206 data from the database 80 or, if more authority is granted, a user may actually have the ability to design 204 or change 204 the data or schema of a database 80.
  • the service module 64 may translate the request from the web server 68 into any database language necessary for communication with the database.
  • the service module 64 may be configured to communicate with any SQL compliant database.
  • the service module 64 may then retrieve or change information contained witliin the database 80. Such information may include data, tables, forms, queries, reports, web pages, user profiles, or other data.
  • the service module 64 may also parse any data from the database 80 and execute any logic found therein.
  • a result may be subsequently determined by the service module 64. Accordingly, the result may then be forwarded to the web server 68 and on to the browser 86 for viewing by a user.
  • the service module 64 effectively acts as an interface between a web server 68 and a database 80.
  • a process is illustrated whereby an anonymous request 210 is received by a browser in accordance with one presently preferred embodiment of the present invention.
  • a browser and server establish a communication link 212. Once the communication link is established, the server then forwards the request 214 to the service module 64 or application 64 of the present invention.
  • the application 64 or service module 64 may then process the request and return the result to the server 216. Processing the request includes receiving a request to access data in a database from the server. Once the request is received, the requested data is then retrieved from the database. The service module 64 or application 64 may then parse any data retrieved and execute any logic found therein 222, creating a result. The result is subsequently forwarded to the server.
  • the result may then be forwarded to the browser 226 where it may be displayed to a user 228.
  • a flow chart is illustrated wherein a secure connection is requested by a client through a browser. As described in Figure 7, a browser and server must first establish a communication link 212. Once the communication link is established, the server may then forward the request 214 to the service module 64 or application 64.
  • the application may then process the request and return the result to the server 216.
  • the steps for processing a secure request by the application 216 include, first, receiving the request to establish a secure connection 232.
  • the service module 64 or application 64 may then verify authentication information and send an authentication token to the browser 234.
  • the browser may then store the authentication token for later use 236.
  • the service module 64 may then process the request by retrieving the data 220, parsing the retrieved data and executing any logic in the data 222, and forwarding the result to the server 224. Once the server receives the result, the result may then be forwarded to the browser
  • the browser may send the authentication token to the server with each following request.
  • the authentication token may be a cookie placed on a user's computer.
  • the present invention provides an effective browser-based database access engine that may be used across the Internet.
  • the present invention provides apparatus and methods to remotely access and modify the data and schema of a database, through a network such as the Internet, using nothing more than a simple browser application.
  • the present invention further provides a method whereby embedded coding within HTML web pages may be interpreted into SQL commands for communicating with any SQL compliant database.
  • the present invention provides all the utility of a typical database through a web-based interface and an efficient method for maintaining and updating web sites using the utility of a database.
  • the present invention enables programming logic to be actually embedded within the code of a web page, provides a manner whereby information is dynamically updated on a web page corresponding to changes in data in a database, and increases the flexibility of a database by allowing a browser, web-server, and database to be located on a single computer or on computers at opposite ends of the globe, if needed or desired.
  • the present invention may be embodied in other specific forms without departing from its spirit or essential characteristics.
  • the described embodiments are to be considered in all respects only as illustrative, and not restrictive.
  • the scope of the invention is, therefore, indicated by the appended claims, rather than by the foregoing description. All changes which come within the meaning and range of equivalency of the claims are to be embraced within their scope.

Abstract

A method and apparatus are described for a browser-based, database-access engine. Access to and modification of database data and schema are made available to a user (210) remotely through a network (212) such as the Internet. The invention is configured to parse (222) the HTML code to interpret special tags embedded in the HTML encoded web pages which could, for example be interpreted in SQL in order to communicate with an SQL compliant database, or, alternatively, the tags could be interpreted into any other database language. The invention is operable on a single machine, or a network environment such as a client/server environment, an intranet, or the internet. The present invention makes a simple browser application connected to the Internet a convenient database management tool for the storage, manipulation, and retrieval (228) of data.

Description

BROWSER-BASED DATABASE-ACCESS ENGINE APPARATUS AND METHOD
BACKGROUND 1. The Field of the Invention
This invention relates to computer software and, more particularly, to novel systems and methods for accessing databases through computer networks including, without limitation, local area networks, wide area networks, and global networks.
2. The Background Art
Databases are very useful and powerful. Likewise, database management systems and engines for accessing databases abound. Unfortunately, many database management systems require a cadre of management information systems personnel and often programmers and computer gurus to make the data useful and available to users. Of course, these human resources do not come without a cost. In some cases, users may need training to work with database query languages or graphical user interfaces. In effect, without the correct skilled personnel or necessary expertise, data becomes virtually useless to the users thereof.
Coordination and synchronization of data often keeps data physically close to one or several homes or repositories. This necessitates the often undesirable condition that database experts be located physically near these few homes or repositories in order to perform maintenance and troubleshooting. This reality alone can cause a certain degree of inflexibility and inconvenience. Online databases, such as those that are accessible in a wide variety over the Internet, are becoming increasingly common. With a few short keystrokes, immense amounts of information from all over the globe are accessible by the common individual. The emerging Internet is resulting in many time-saving advances making data available from virtually anywhere. However, while access to the data in these databases may be common, the ability to actually manage and manipulate the schema of such databases over networks, such as the Internet, is not.
At present, the ability to manage and manipulate the data of a database, including the end user data and the schema of a database, through a network, such as the Internet, is very limited. What is needed is a way for users to have access and control of the data, including the end user data and the schema of a database, irrespective of the type or origin of the database, through a network, such as the Internet.
What is further needed is a seamless and transparent way for users to manipulate the data, and even the schema of a database in a system that does not require a high level of expertise or training.
It would be an advance in the art to enable users to perform the foregoing functions remotely, such as through the Internet, with a common software package, such as a standard browser application. Such a system would allow users to view and modify the data and schema of a database on opposite ends of the globe, if desired or needed. In addition, such a system would eliminate the necessity to load specialized database management software onto a computer or terminal of a user.
Moreover, it would be a further advance in the art to provide a system capable of recognizing and functioriing with a wide variety of different databases in a manner that would be transparent to a user.
BRIEF SUMMARY OF THE INVENTION In accordance with the invention as embodied and broadly described herein, a method and apparatus are disclosed in one embodiment of the present invention as including a computer having a browser, having a communication link established with a web server, and making a request thereto. The web server, upon receiving the request, may then forward the request to the service module of the present invention. The service module may be located on the same computer as the web server, or be hosted by an application server, in certain embodiments. According to the level of access afforded to a user, a user may have the ability to view data from the database or, if more authority is granted, a user may actually have the ability to modify the data or schema of a database. In effect, a user may be able to manage a database remotely, using nothing more than a simple browser application. The database may be located on a server located remotely from the web server, connected by the Internet, or may be located on the same computer as the web server. In another embodiment, a browser, web server, service module, and database may all be hosted on the same computer. The service module of the present invention may be configured to translate requests made to a web server into a database language necessary for communication with a database. In certain embodiments, the service module may be configured to communicate with any SQL compliant database. Once a request is made to the service module and authority is granted to a user, the service module may then retrieve or change information contained within a database. Such information may include data, tables, forms, queries, reports, web pages, user profiles, or other data. In certain embodiments, web pages may be stored at one location in a database while data stored at another location may supply content to the web pages. Thus, the present invention provides an efficient apparatus and method for maintaining and updating web sites by dynamically retrieving data each time a web page is called by a browser.
In addition to retrieving data, the service module may also parse any data retrieved from the database and execute any logic found therein. Special tags may be included within the HTML coding of web pages, which may not be recognized by a typical browser, but may be understood by the service module of the present invention and may be used to execute instructions. For example, conditional statements may be included to forward a user to distinct web pages depending on the input entered by a user. Alternatively, an instruction programmed within the source code of a web page may be executed to actually retrieve data from a database to be inserted into the web page. Once the data is retrieved and any logic found therein is executed, the result may be subsequently forwarded to the web server and on to the browser for viewing by a user. Thus, the service module may effectively act as an interface between a web server and a database.
BRIEF DESCRIPTION OF THE DRAWINGS The foregoing and other objects and features of the present invention will become more fully apparent from the following description and appended claims, taken in conjunction with the accompanying drawings. Understanding that these drawings depict only typical embodiments of the invention and are, therefore, not to be considered limiting of its scope, the invention will be described with additional specificity and detail through use of the accompanying drawings in which:
Figure 1 is a schematic block diagram of one architecture for a hardware suite suitable for implementing an apparatus in accordance with the present invention; Figure 2 is a schematic block diagram illustrating various possible implementations of the present invention;
Figure 3 is a schematic block diagram of the service module, startup configuration data, and database records contained within memory in accordance with the invention; Figure 4 is a schematic block diagram of various functions performed by the service module of the present invention;
Figure 5 is a schematic block diagram of one embodiment of database records accessed by the service module of the present invention;
Figure 6 is a schematic block diagram illustrating the flow of communication performed by the present invention;
Figure 7 is a flow chart showing the sequence of steps performed by the present invention when an anonymous request is made; and
Figure 8 is a flow chart showing the sequence of steps performed by the present invention when a secure request is made.
DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS It will be readily understood that the components of the present invention, as generally described and illustrated in the Figures herein, could be arranged and designed in a wide variety of different configurations. Thus, the following more detailed description of the embodiments of the system and method of the present invention, as represented in Figures
1 through 8, is not intended to limit the scope of the invention, as claimed, but it is merely representative of the presently preferred embodiments of the invention.
The presently preferred embodiments of the invention will be best understood by reference to the drawings, wherein like parts are designated by like numerals throughout. Those of ordinary skill in the art will, of course, appreciate that various modifications to the details illustrated in the schematic diagrams of Figures 1-8 may easily be made without departing from the essential characteristics of the invention. Thus, the following description is intended only as an example, and simply illustrates one presently preferred embodiment consistent with the invention as claimed herein. Referring now to Figure 1, an apparatus 10 of one presently preferred embodiment of the present invention may include a node 11 (client 11, computer 11) containing a processor 12 or CPU 12. The CPU 12 may be operably connected to a memory device 14. A memory device 14 may include one or more devices such as a hard drive 16 or non- volatile storage device 16, a read-only memory 18 (ROM), and a random-access (and usually volatile) memory 20 (RAM).
In one presently preferred embodiment, the apparatus 10 may include an input device 22 for receiving inputs from a user or another device. Similarly, an output device 24 may be provided within the node 11, or accessible within the apparatus 10. A network card 26
(interface card) or port 28 may be provided for connecting to outside devices, such as the network 30.
Internally, a bus 32 (system bus 32) may operably interconnect the processor 12, memory devices 14, input devices 22, output devices 24, network card 26 and port 28. The bus 32 may be thought of as a data carrier. As such, the bus 32 may be embodied in numerous configurations. Wire, fiber optic line, wireless electromagnetic communications by visible light, mfrared, and radio frequencies may likewise be implemented as appropriate for the bus 32 and the network 30. Input devices 22 may include one or more physical embodiments. For example, a keyboard 34 may be used for interaction with the user, as may a mouse 36. A touch screen 38, a telephone 39, or simply a telephone line 39, may be used for communication with other devices, with a user, or the like.
Similarly, a scanner 40 may be used to receive graphical inputs which may or may not be translated to other character formats. A hard drive 41 or other memory device 14 may be used as an input device whether resident within the node 11 or some other node 52 (e.g., 52a, 52b, etc.) on the network 30, or from another network 50.
Output devices 24 may likewise include one or more physical hardware units. For example, in general, the port 28 may be used to accept inputs and send outputs from the node 11. Nevertheless, a monitor 42 may provide outputs to a user for feedback during a process, or for assisting two-way communication between the processor 12 and a user. A printer 44 or a hard drive 46 may be used for outputting information as output devices 24.
In general, a network 30 to which a node 11 connects may, in turn, be connected through a router 48 to another network 50. i general, two nodes 11 , 52 may be on a network 30, adjoining networks 30, 50, or may be separated by multiple routers 48 and multiple networks 50 as individual nodes 11, 52 on an internetwork. The individual nodes 52 may have various communication capabilities. In certain presently preferred embodiments of the present invention, a minimum of logical capability may be available in any node 52. Note that any of the individual nodes 52 may be referred to, as may all together, as a node 52 or nodes 52.
A network 30 may include one or more servers 54. Servers may be used to manage, store, communicate, transfer, access, update, and the like, any number of files for a network
30. Typically, a server 54 may be accessed by all nodes 11, 52 on a network 30.
Nevertheless, other special functions, including communications, applications, and the like may be implemented by an individual server 54 or multiple servers 54.
In general, a node 11 may need to communicate over a network 30 with a server 54, a router 48, or nodes 52. Similarly, a node 11 may need to communicate over another network (50) in an internetwork connection with some remote node 52. Likewise, individual components of the apparatus 10 may need to communicate data with one another. A communication link may exist, in general, between any pair of devices or components.
By the expression "nodes" 52 is meant any one or all of the nodes 48, 52, 54, 56, 58, 60, 62, 11. Thus, any one of the nodes 52 may include any or all of the component parts illustrated in the node 11. The node 60 hosts the software and data structures required for providing directory services to the nodes 52 in the network 30 and may do so for other nodes 52 in other networks 50. The node 60 may typically be a server 54 in a network. However, it may be installed in any node 52. A node 52 may typically include a network card 26 for connecting to the network 30, a processor 12 for processing software commands, a memory device 20 for operational memory as well as a non- volatile storage device 16 such as a hard drive 16. Typically, an input device 22 and an output device 24 are provided for user interaction with the node 60.
Referring to Figure 2, while continuing to refer to Figure 1, in general, any number of workstation nodes 58, 62 may exist in a network 30, within some practical limit. Any network 30, 50 may be part of, and connect to the Internet 76. In certain embodiments, a user may be connected to the Internet 76 through an Internet service provider 74a. The user 72 may be any computer system, such as system 11 in Figure 1 , having a browser 86a. The user 72 may be configured to communicate with a web server 68a that is configured to provide web pages that are stored in the memory of the web server 68a and are viewable by a user 72.
A service module 64a may also be located in the memory of the web server by 68a and may comprise executable and operational data structures configured to be processed in the processor of the web server 68a.
When a request for a web page is made by a browser 86a to a web server 68a, the service module 64a may be configured to retrieve the web page data from a location in a database 80a on a remotely located database server, such as server 78a.
In addition, the service module 64a may actually process programming embedded within the HTML coding of web pages located on the database server 78a. The programming may comprise executable logic that may dynamically retrieve data within another location in the database 80a to provide content to the web page. Such executable logic may be coded in a language understandable by the service module 64a of the present invention. The logic may be embedded within special tags contained in the HTML-encoded page. These special tags are typically configured to be ignored by the typical browser, but these special tags configured to be understood and executed by the service module 64a of the present invention.
In certain instances, the executable logic may comprise conditional statements that may be executed in response to user input. For example, coding may be included within a web page to process conditional "if statements, such as when receiving a password from a user. In this example, if a user types the incorrect password, the coding within the web page may be configured to deny a user access and/or may forward the user to another specific web page. Additionally, input by a user through the browser 86a may be processed by the service module 64a to modify the data and/or even the schema of the database 80a.
Thus, in the depicted configuration, a user 72, web server 68a, and database server 78a, may be connected to the Internet 76 to function in accordance with the invention while being physically located at geographically distant locations around the Earth. In reality, a user need not be a single user 72, but may actually be any user connected to the Internet 76, such as a plurality of users 70a-c connected by a local area network (LAN) 86. Any user 70c, such as users 70a, 70b, 70c, and 72, having a browser 86b, such as browsers 86a, 86b, and 86c, with Internet access may access the web server 68a and the database 80a. In an alternate preferred embodiment, the service module 64b may actually be located on an ASP (application service provider) server 66. Therefore, a web server 68b may forward a request to a service module 64b located on ASP server 66. hi turn, the service module 64b may retrieve or modify data and/or schema in a database 80a on a server 78a. In the depicted embodiment, the application server 66 may be configured to provide to a plurality of businesses or individuals the services of the service module 64b. Thus, in the depicted configuration, any need to install the service module 64b on one or more web server(s) may be avoided.
In certain embodiments of the present invention, the service module 64c, database 80b, and browser 86c may all be located on a computer of a single user 70d.
In another embodiment, a service module 64d and database 80c may both be located on the web server 68c and may be accessed by any user 72 and/or group of users 70a-c connected to the Internet.
In yet another embodiment of the present invention, a service module 64e may be located on an enterprise server 84 connected to a database server 78b. A plurality of workstations 82a, 82b, each having thereon a browser 84d and each in operable communication with the enterprise server 84, may access the database server 78b through the server 84.
Thus, the foregoing descriptions illustrate the versatility of the present invention and the various embodiments in which it may be implemented. It will be appreciated by those skilled in the art that the present invention, as illustrated, may be employed according to needs of a particular user or users. Hence, the data, including end user data and schema, of a remotely located database may be modified with the only client software being a simple browser application.
Referring now to Figure 3, in one presently preferred embodiment of the present invention, a memory device 14 in a computer 11 , which computer 11 may be disposed in any of the configurations discussed in connection with Figure 2, may include a service module 64 comprising a table management module 90, a forms management module 92, a query management module 94, a report management module 96, a web management module 98, a user management module 99, and other modules 100. A memory device 14 may also store startup and configuration data 102 used to initiate the service module 64. Additionally, a memory device 14 may actually store a database 80, which may comprise records or tables populated with data.
Typically, a database stores information within some type of a schema, such as records or tables. A table management module 90, therefore, may be used in accordance with the present invention to manage the schema, typically embodied as tables, of one or more databases(s). Such tables will be explained in further detail in the description of Figure 4. The table management module 90 may enable a user and/or several users to alter the schema or structure of a database, if desired. Forms provide a convenient and graphical way for a user to populate a database with data. Data entry may be simplified by providing a user with graphical boxes or areas where data may be input. Consequently, a forms management module 92 may be included with the present invention to design and manage forms to be used for data input.
One of the major advantages of databases is the ability to search the data contained therein according to specific criteria. Such searches may also be called queries and represent the communication that occurs between a database engine and a database. Most databases typically use a standard query language. The present invention may include a query management module 94 to manage any queries of a database.
It also may be useful for a user of a database to be able to process reports of the data contained within a database. Such reports may allow a user to compare, view, and analyze specific data within the database. Consequently, a report management module 98 may be included in the service module 64 to manage such database reports.
With the continued growth of the Internet, the ability to access the data, including without limitation end user data and database schema, of a database through the Internet is becoming an important feature to many users. A web management module 98 may be included with the present invention wherein web pages may be more easily managed. The web management module 98 may be used to create web pages whose content may be dynamically updated as data in the database changes. This ability to dynamically update the content of web pages may provide a tremendous time savings by eliminating much of the programming required to update content in static web pages.
A user management module 99 may also be included with the present invention to control users' access to a database and to control the level of access granted thereto. For example, some users may be granted access only to view data, whereas other users may be granted privileges to access and modify not only the data of a database, but also the schema. The level of access and privileges may be customized according to the individual user. Such a feature may provide a needed level of security to control access to a database granted to some users while still providing an increased level of access to other users. In addition, other modules 100 may be included in the service module 64 as needed to provide additional functions.
Referring now to Figure 4, a service module 64 of the present invention may include a table management module 90 providing the ability to alter the schema or structure of a database. For example, a user may be able to add 104, edit 106, or delete 108 tables according to the configuration required of a database. Likewise, a user may be able to list 110 existing tables within a database or view 112 the data contents of a table. Accordingly, other functions 114 or tools 114 that may provide a user the ability to modify, view, or work with tables in a database may be provided in the table management module 90 of the present invention.
In addition, the table management module 90 may allow a user to populate a table with data. For example, a user may add 116, edit 118, or delete 120 fields within each table. Likewise a user may list 122, search 126, or view 124 data within a table. Other tools 126 or functions 126 may also be provided as needed to work with the data in a database. The forms management module 92 may be included within the service module 64 of the present invention to enable a user to design and work with forms. A user may choose to design a form or actually use the form to input data to a database. For example, a user may choose to add 128, edit 130, or delete 132 a form. In addition, a user may choose to list 134 existing forms or view 136 a particular form. Once a form is created, it may then be used 138 to add 120, edit 118, or delete 116 data.
Likewise, a query management module 94 may be included with the present invention to create and execute queries. A query may be added 128, edited 130, or deleted 132. Likewise a query management module 94 may be used to list 146 queries or view a particular query 148. Once a query is created, it may be executed 150 in order to search a database based on chosen criteria.
A report management module 96 may also be included in the service module 64 of the present invention to create and run reports. Like the previous modules discussed, reports may be added 152, edited 154, or deleted 156. In addition, reports that have been created may be listed 158 or a particular report may be viewed 160. Once a report has been created, it may be run 162 whereby the data is actually retrieved from a database to populate the report with data. A web management module 98 may be included in the present invention to allow a user to create web pages. The present invention offers the advantage of allowing the design of web pages that may be dynamically updated, thus saving time that might be lost reprogramming static pages. Logic may be added within an HTML encoded web page that is understandable by the service module 64 that will actually retrieve the current data contents of a location in a database to provide content to a web page. Thus, a web page may be updated simply by changing the data in the database to which it refers, addition prograriiming logic may be embedded in the HTML coding that may be executed in accordance with the present invention. The web management module 98 may provide a user the ability to add 164, edit 166, or delete 168 web pages. In addition a user may be able to list 170 existing web pages or view 172 a particular web page. Once a web page is created, it may be processed, upon viewing by a user, wherein data is retrieved from a database to provide web page content and any logic contained therein is executed. The service module 64 may also include a user management module 99 provided to manage levels of access granted to users registered therein. In certain embodiments, any anonymous user may be allowed to view data, while only certain users may be granted the authority to actually alter the data or schema of a database. The user management module 99 may allow the adding 176 or deleting 180 of a user by a user with administrative authority. Likewise, a user profile may be edited 178 such as when changing the level of access or authority of a particular user. Additionally the module 99 may allow a user or administrator to view a list of registered users or view the profile of a particular user. In certain presently preferred embodiments, once a user is added, a user may actually gain access to a database by entering a particular user ID and password. In addition to the modules illustrated in the foregoing description, the present invention may make use of other modules as additional functions are needed. Like the other modules, the criteria may be added, edited, deleted, listed, viewed, or processed in accordance with the invention.
Referring now to Figure 5, in one presently preferred embodiment, a database 80 contained in memory 14 may be comprised of a plurality of tables 190, 192, 194. Some of the tables may contain data while other tables may contain schema 200 information or indices 202 of the other tables 190, 192, 194. For example, in one embodiment of the present invention, a table 190 may contain web page templates 196, while another table 192 may contain the content 198 or data 198 used in the web page templates 196. Upon viewing a web page 196 contained within the table 190, coding embedded with the web pages 196 may contain instructions to pull data 198 or content 198 from the table 192. In HTML web page source code, which is typically coded with "special tags." Such special tags may be used in accordance with the present invention to interact with executable and often embedded logic. Such logic may either be instructions to retrieve data as previously stated or may contain other executable instructions.
Users with proper authority may be able to alter the schema 200 of the database 80. such alteration of the schema 200 may include adding, editing, or deleting any of the tables
190, 192, 194 or any other function that may alter the structure or architecture of the database. Since it may not be desirable that arbitrary users have access to alter the schema of the database, this privilege may be reserved for authorized users only.
In general, typical database systems that are presently accessible over the Internet may allow access to the data in a database 80, but such database systems have no mechanism for allowing the modification of the schema 200 of a database 80 across the Internet using only a browser application. The ability to modify the schema 200 of a database 80 across the Internet using only a browser application is an advantage that is provided by the present invention. Referring now to Figure 6, a flow chart showing the flow of communication in accordance with the present invention is illustrated. A browser 86, having a communication link established with a web server 68, may make a request therefrom. This request may subsequently be forwarded to the service module 64 of the present invention. According to the level of access afforded to a user, a user may be granted the ability to view 206 or use 206 data from the database 80 or, if more authority is granted, a user may actually have the ability to design 204 or change 204 the data or schema of a database 80. The service module 64 may translate the request from the web server 68 into any database language necessary for communication with the database. In certain embodiments, the service module 64 may be configured to communicate with any SQL compliant database. Once the request is made to the service module 64 and authority is granted to a user, the service module 64 may then retrieve or change information contained witliin the database 80. Such information may include data, tables, forms, queries, reports, web pages, user profiles, or other data. In addition to retrieving data, the service module 64 may also parse any data from the database 80 and execute any logic found therein.
Once the data is retrieved and any logic found therein is executed, a result may be subsequently determined by the service module 64. Accordingly, the result may then be forwarded to the web server 68 and on to the browser 86 for viewing by a user. Thus, the service module 64 effectively acts as an interface between a web server 68 and a database 80. Referring now to Figure 7, a process is illustrated whereby an anonymous request 210 is received by a browser in accordance with one presently preferred embodiment of the present invention. Upon receiving the request 210, a browser and server establish a communication link 212. Once the communication link is established, the server then forwards the request 214 to the service module 64 or application 64 of the present invention.
The application 64 or service module 64 may then process the request and return the result to the server 216. Processing the request includes receiving a request to access data in a database from the server. Once the request is received, the requested data is then retrieved from the database. The service module 64 or application 64 may then parse any data retrieved and execute any logic found therein 222, creating a result. The result is subsequently forwarded to the server.
Once the result is received by the server, the result may then be forwarded to the browser 226 where it may be displayed to a user 228. Referring now to Figure 8, a flow chart is illustrated wherein a secure connection is requested by a client through a browser. As described in Figure 7, a browser and server must first establish a communication link 212. Once the communication link is established, the server may then forward the request 214 to the service module 64 or application 64.
The application may then process the request and return the result to the server 216. The steps for processing a secure request by the application 216 include, first, receiving the request to establish a secure connection 232. The service module 64 or application 64 may then verify authentication information and send an authentication token to the browser 234. The browser may then store the authentication token for later use 236. Once the token is received, the service module 64 may then process the request by retrieving the data 220, parsing the retrieved data and executing any logic in the data 222, and forwarding the result to the server 224. Once the server receives the result, the result may then be forwarded to the browser
226 where the it may be displayed for a user 228. In certain embodiments, once a secure connection is established, the browser may send the authentication token to the server with each following request. In certain embodiments, the authentication token may be a cookie placed on a user's computer.
From the above discussion, it will be appreciated that the present invention provides an effective browser-based database access engine that may be used across the Internet. Specifically, the present invention provides apparatus and methods to remotely access and modify the data and schema of a database, through a network such as the Internet, using nothing more than a simple browser application. The present invention further provides a method whereby embedded coding within HTML web pages may be interpreted into SQL commands for communicating with any SQL compliant database. In addition, the present invention provides all the utility of a typical database through a web-based interface and an efficient method for maintaining and updating web sites using the utility of a database. Moreover, the present invention enables programming logic to be actually embedded within the code of a web page, provides a manner whereby information is dynamically updated on a web page corresponding to changes in data in a database, and increases the flexibility of a database by allowing a browser, web-server, and database to be located on a single computer or on computers at opposite ends of the globe, if needed or desired. The present invention may be embodied in other specific forms without departing from its spirit or essential characteristics. The described embodiments are to be considered in all respects only as illustrative, and not restrictive. The scope of the invention is, therefore, indicated by the appended claims, rather than by the foregoing description. All changes which come within the meaning and range of equivalency of the claims are to be embraced within their scope.

Claims

1. An apparatus for using a database through a web-based interface, the apparatus comprising: a processor configured to execute executable data structures; a memory device connected to the processor for storing the executable data structures and associated operational data structures, the executable and operational data structures comprising: a database server configured to host a database having both data and schema; a web server configured to receive requests from and publish responses to a browser, the browser being in operable communication with the web server; and a service module configured to store and retrieve web pages located in the database.
2. The apparatus of claim 1, wherein the service module is further configured to interpret requests received by the web server from the browser into a database language for communicating with the database, thereby allowing a user to view and modify the data and schema of the database.
3. The apparatus of claim 2, wherein the service module is further configured to provide user management of a plurality of users, thereby providing each user an arbitrary level of access and control of the database data and schema.
4. The apparatus of claim 3, wherein the service module comprises a web management module configured to allow a user to embed logic within the source code of web pages, the embedded logic allowing the web pages to be dynamically updated by data in the database.
5. The apparatus of claim 4, wherein the service module interprets the embedded logic in the web pages into the database language.
6. The apparatus of claim 5, wherein the embedded logic comprises instructions executable by the processor.
7. The apparatus of claim 6, wherein the database language is SQL.
8. The apparatus of claim 7, wherein the service module comprises a table management module configured to design and populate tables within the database.
9. The apparatus of claim 1, wherein the service module is configured to interpret requests received by the web server from the browser into a database language for communicating with the database, thereby allowing a user to view and modify the data and schema of the database.
10. The apparatus of claim 1 , wherein the service module is configured to provide user management of a plurality of users, thereby providing each user an arbitrary level of access and control of the database data and schema.
11. The apparatus of claim 1, wherein the service module comprises a web management module configured to allow a user to embed logic within the source code of web pages, the embedded logic allowing the web pages to be dynamically updated by data in the database.
12. The apparatus of claim 1, wherein the service module is configured to allow a user to embed logic within the source code of web pages and interpret the embedded logic into the database language.
13. The apparatus of claim 1 , wherein the service module is configured to allow a user to embed logic within the source code of web pages, the embedded logic comprising instructions executable by the processor.
14. The apparatus of claim 9, wherein the database language is SQL.
15. The apparatus of claim 1, wherein the service module comprises a table management module configured to design and populate tables within the database.
16. A method for viewing web pages stored in a database, the method comprising the steps of: establishing a communication link between a browser and a web server, wherein a user makes a request through the browser to the web server to view web pages in a database; forwarding the request from the web server for processing by a service module, wherein processing by the service module comprises: receiving the request from the web server; and executing the request, thereby providing a result, wherein executing the request comprises : retrieving the web page from the database corresponding to the request; parsing the web page and executing any logic found therein; and forwarding the result to the web server; and forwarding the result from the web server to the browser.
17. The method of claim 18, wherein the service module interprets requests made by the web server into a language necessary to communicate with the database.
18. A method for manipulating the data and schema of a database through a web- based interface, the method comprising the steps of: establishing a communication link between a browser and a web server, wherein a user makes a request through the browser to the web server to manipulate the data and schema of a database; forwarding the request from the web server for processing by a service module, wherein processing by the service module comprises: determining the level of access granted to the user; permitting the user to modify the data of the database corresponding to the level of access granted thereto; receiving the request from the web server; and executing the request, thereby providing a result, wherein executing the request comprises: manipulating the data and schema of the database corresponding to the request; parsing the data and executing any logic found therein; forwarding the result to the web server; and forwarding the result from the web server to the browser.
19. The method of claim 18, wherein manipulating is selected from the group consisting of viewing and modifying.
20. The method of claim 19, wherein the data is web pages.
PCT/US2001/013525 2000-04-26 2001-04-26 Browser-based database-access engine apparatus and method WO2001084372A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
AU2001259180A AU2001259180A1 (en) 2000-04-26 2001-04-26 Browser-based database-access engine apparatus and method

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US19985000P 2000-04-26 2000-04-26
US60/199,850 2000-04-26
US09/843,331 2001-04-25

Publications (1)

Publication Number Publication Date
WO2001084372A1 true WO2001084372A1 (en) 2001-11-08

Family

ID=22739279

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2001/013525 WO2001084372A1 (en) 2000-04-26 2001-04-26 Browser-based database-access engine apparatus and method

Country Status (3)

Country Link
US (1) US6460041B2 (en)
AU (1) AU2001259180A1 (en)
WO (1) WO2001084372A1 (en)

Families Citing this family (52)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20010054044A1 (en) * 2000-06-14 2001-12-20 Liu Yi Bo Method for monitoring and browsing database of test system
US8600783B2 (en) 2000-08-18 2013-12-03 The Crawford Group, Inc. Business to business computer system for communicating and processing rental car reservations using web services
US7899690B1 (en) 2000-08-18 2011-03-01 The Crawford Group, Inc. Extended web enabled business to business computer system for rental vehicle services
US7386495B2 (en) 2001-03-23 2008-06-10 International Business Machines Corporation System and method for processing tax codes by company group
US6950983B1 (en) * 2000-09-07 2005-09-27 International Business Machines Corporation System and method for populating HTML forms using relational database agents
US8027892B2 (en) 2001-03-28 2011-09-27 International Business Machines Corporation System and method for automating invoice processing with positive confirmation
US7155403B2 (en) 2001-03-22 2006-12-26 International Business Machines Corporation System and method for leveraging procurement across companies and company groups
US7885981B2 (en) * 2000-10-31 2011-02-08 Michael Philip Kaufman System and method for generating automatic user interface for arbitrarily complex or large databases
WO2002059793A2 (en) * 2000-10-31 2002-08-01 Michael Philip Kaufman System and method for generating automatic user interface for arbitrarily complex or large databases
US8161081B2 (en) 2001-03-16 2012-04-17 Michael Philip Kaufman System and method for generating automatic user interface for arbitrarily complex or large databases
US6917930B1 (en) * 2000-11-20 2005-07-12 Amdocs Software Systems Limited Database integrity in an internet e-commerce environment
US7222291B2 (en) * 2000-12-29 2007-05-22 International Business Machines Corporation Method and system for importing HTML forms
US7739298B1 (en) * 2001-01-26 2010-06-15 Apple Inc. Using a calculation expression to define and control access rights for records in a database
US8391298B2 (en) * 2001-02-01 2013-03-05 Estech Systems, Inc. Phone directory in a voice over IP telephone system
US7533336B2 (en) * 2001-03-01 2009-05-12 International Business Machines Corporation Method and apparatus for facilitating construction of e-commerce web pages having featured products and the like
US7243077B2 (en) 2001-03-02 2007-07-10 International Business Machines Corporation Method and computer program product for managing an internet trading network
US6804679B2 (en) * 2001-03-12 2004-10-12 Affymetrix, Inc. System, method, and user interfaces for managing genomic data
US20030088569A1 (en) * 2001-04-19 2003-05-08 Rubert Amy L. Configuring access to database
US20030061106A1 (en) * 2001-09-21 2003-03-27 Sunday Orhomuru Data transfer or transfer of data using wireless mobile phone and any other wireless mobile devices
US8166006B2 (en) * 2001-09-28 2012-04-24 International Business Machines Corporation Invocation of web services from a database
US8924408B2 (en) * 2001-09-28 2014-12-30 International Business Machines Corporation Automatic generation of database invocation mechanism for external web services
US8914807B2 (en) * 2001-09-28 2014-12-16 International Business Machines Corporation Method, system, and program for generating a program capable of invoking a flow of operations
US20030225853A1 (en) * 2001-10-18 2003-12-04 Wang John Y. Method and system for constructing a database-driven website
US20030105758A1 (en) * 2001-12-05 2003-06-05 International Business Machines Corporation System and method for testing and promoting database update code
US7386468B2 (en) * 2002-01-08 2008-06-10 International Business Machines Corporation System and method for resource reduction receipt log and audit trail
US7496952B2 (en) * 2002-03-28 2009-02-24 International Business Machines Corporation Methods for authenticating a user's credentials against multiple sets of credentials
US20040039612A1 (en) 2002-06-14 2004-02-26 Neil Fitzgerald Method and apparatus for customer direct on-line reservation of rental vehicles
US8108231B2 (en) 2002-06-14 2012-01-31 The Crawford Group, Inc. Method and apparatus for improved customer direct on-line reservation of rental vehicles
KR20060103428A (en) * 2003-09-17 2006-09-29 리서치 인 모션 리미티드 System and method for dynamic content processing with extendable provisioning
CN100437516C (en) * 2003-09-24 2008-11-26 索尼株式会社 Database schemer update method
US20050071359A1 (en) * 2003-09-25 2005-03-31 Elandassery Deepak S. Method for automated database schema evolution
JP4286736B2 (en) * 2004-07-12 2009-07-01 富士通株式会社 Internet protocol telephone number guidance system
US20060047810A1 (en) * 2004-09-02 2006-03-02 Kyle Herzog Asset management system and method
US7519962B2 (en) * 2004-10-07 2009-04-14 Thomson Financial Llc Command script parsing using local and extended storage for command lookup
US7519622B2 (en) * 2004-11-16 2009-04-14 Unival, Inc. System and method for collecting data from data sources using data collection tools
US20060106789A1 (en) * 2004-11-16 2006-05-18 Unival, Inc. System and method for collecting data from data sources using data collection tools
US7930363B2 (en) * 2005-10-12 2011-04-19 Powerreviews, Inc. Application service provider delivery system
US7617190B2 (en) * 2005-11-29 2009-11-10 Microsoft Corporation Data feeds for management systems
US7912933B2 (en) * 2005-11-29 2011-03-22 Microsoft Corporation Tags for management systems
US8271309B2 (en) 2006-03-16 2012-09-18 The Crawford Group, Inc. Method and system for providing and administering online rental vehicle reservation booking services
US8082294B2 (en) 2007-06-27 2011-12-20 Concept Solutions, Llc Methods and systems for providing web applications
US20100042719A1 (en) * 2008-08-12 2010-02-18 Junji Kinoshita Content access to virtual machine resource
JP2014500538A (en) 2010-10-12 2014-01-09 タニス,ケヴィン ジェイ. Medical equipment
US10049125B2 (en) * 2012-03-30 2018-08-14 Allscripts Software, Llc Methods, apparatuses, and computer program products for identifying fields in a data tree
US9737649B2 (en) 2013-03-14 2017-08-22 Smith & Nephew, Inc. Systems and methods for applying reduced pressure therapy
US11315681B2 (en) 2015-10-07 2022-04-26 Smith & Nephew, Inc. Reduced pressure therapy device operation and authorization monitoring
AU2017261814B2 (en) 2016-05-13 2022-05-19 Smith & Nephew, Inc. Automatic wound coupling detection in negative pressure wound therapy systems
AU2017335635B2 (en) 2016-09-29 2023-01-05 Smith & Nephew, Inc. Construction and protection of components in negative pressure wound therapy systems
US11712508B2 (en) 2017-07-10 2023-08-01 Smith & Nephew, Inc. Systems and methods for directly interacting with communications module of wound therapy apparatus
US10956392B1 (en) 2018-07-23 2021-03-23 Allscripts Software, Llc Methods, apparatuses, and computer program products for identifying fields in a data tree
GB201820668D0 (en) 2018-12-19 2019-01-30 Smith & Nephew Inc Systems and methods for delivering prescribed wound therapy
CN116010382A (en) * 2023-02-24 2023-04-25 天翼云科技有限公司 Operation and maintenance method, device and equipment of database and storage medium

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5987454A (en) * 1997-06-09 1999-11-16 Hobbs; Allen Method and apparatus for selectively augmenting retrieved text, numbers, maps, charts, still pictures and/or graphics, moving pictures and/or graphics and audio information from a network resource
US5999941A (en) * 1997-11-25 1999-12-07 Micron Electronics, Inc. Database access using active server pages
US6012067A (en) * 1998-03-02 2000-01-04 Sarkar; Shyam Sundar Method and apparatus for storing and manipulating objects in a plurality of relational data managers on the web
US6038566A (en) * 1996-12-04 2000-03-14 Tsai; Daniel E. Method and apparatus for navigation of relational databases on distributed networks

Family Cites Families (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6016394A (en) 1997-09-17 2000-01-18 Tenfold Corporation Method and system for database application software creation requiring minimal programming
US6131096A (en) 1998-10-05 2000-10-10 Visto Corporation System and method for updating a remote database in a network

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6038566A (en) * 1996-12-04 2000-03-14 Tsai; Daniel E. Method and apparatus for navigation of relational databases on distributed networks
US5987454A (en) * 1997-06-09 1999-11-16 Hobbs; Allen Method and apparatus for selectively augmenting retrieved text, numbers, maps, charts, still pictures and/or graphics, moving pictures and/or graphics and audio information from a network resource
US5999941A (en) * 1997-11-25 1999-12-07 Micron Electronics, Inc. Database access using active server pages
US6012067A (en) * 1998-03-02 2000-01-04 Sarkar; Shyam Sundar Method and apparatus for storing and manipulating objects in a plurality of relational data managers on the web

Also Published As

Publication number Publication date
US20010037331A1 (en) 2001-11-01
US6460041B2 (en) 2002-10-01
AU2001259180A1 (en) 2001-11-12

Similar Documents

Publication Publication Date Title
US6460041B2 (en) Browser-based database-access engine apparatus and method
US7289983B2 (en) Personalized indexing and searching for information in a distributed data processing system
US7865494B2 (en) Personalized indexing and searching for information in a distributed data processing system
US8244837B2 (en) Central administration of one or more resources
US6947991B1 (en) Method and apparatus for exposing network administration stored in a directory using HTTP/WebDAV protocol
US6418446B1 (en) Method for grouping of dynamic schema data using XML
US7418440B2 (en) Method and system for extraction and organizing selected data from sources on a network
Dowler et al. Table access protocol version 1.0
US6996622B2 (en) Session managing method, session managing system, and program
US6918088B2 (en) Service portal with application framework for facilitating application and feature development
US5771355A (en) Transmitting electronic mail by either reference or value at file-replication points to minimize costs
KR100843828B1 (en) Method and apparatus for managing a collection of portlets in a portal server
US7016959B2 (en) Self service single sign on management system allowing user to amend user directory to include user chosen resource name and resource security data
US7818435B1 (en) Reverse proxy mechanism for retrieving electronic content associated with a local network
US6907423B2 (en) Search engine interface and method of controlling client searches
US7873649B2 (en) Method and mechanism for identifying transaction on a row of data
US6523062B1 (en) Facilitating memory constrained client devices by employing deck reduction techniques
US7334039B1 (en) Techniques for generating rules for a dynamic rule-based system that responds to requests for a resource on a network
JP2000357176A (en) Contents indexing retrieval system and retrieval result providing method
JP2001282594A (en) Corporate work integration system and method for integrating a plurality of data sources
KR20090006167A (en) Permission-based document server
EP0903677B1 (en) Hypertext editing system
US20090319669A1 (en) Method and device for editing web contents by url conversion
US6446117B1 (en) Apparatus and method for saving session variables on the server side of an on-line data base management system
JPH11502346A (en) Computer system and computer execution process for creating and maintaining online services

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BY BZ CA CH CN CR CU CZ DE DK DM DZ EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT TZ UA UG UZ VN YU ZA ZW

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): GH GM KE LS MW MZ SD SL SZ TZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE TR BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
122 Ep: pct application non-entry in european phase
NENP Non-entry into the national phase

Ref country code: JP