This invention generally relates to databases that prohibit outflow of data except when a privacy policy includes a rule permitting disclosure of the data to the appropriate recipient for the appropriate purpose. Specifically, the invention preserves privacy by enforcing limited disclosure rules in an unmodified database at cell-level granularity.
Preserving data privacy is of utmost concern in many business sectors, including e-commerce, healthcare, government, and retail, where individuals entrust others with their personal information every day. Often, the organizations collecting the data will specify how the data is to be used in a privacy policy, which can be expressed either electronically or in natural language.
The authors of [5] proposed the vision of a “Hippocratic” database that is responsible for maintaining the privacy of the personal information it manages. The authors proposed a framework for managing privacy sensitive information distilled down from the private data handling practices that are being demanded internationally, and mandated through legislation such as the United States Privacy Act of 1974 (Fair Information Practices), the EU Privacy Directive which took effect in 1998, the Canadian Standard Association's Model Code for the protection of Personal Information, the Australian Privacy Amendment Act of 2000, the Japanese Personal Information Protection Laws of 2003, and others. The framework is based on ten principles central to managing private data responsibly.
A vital principle among these is “limited disclosure,” which is defined to mean that the database should not communicate private information outside the database for reasons other than those for which there is consent from the data subject. (The term “data subject” means the individual whose private information is stored and managed by the database system.) A straightforward solution would be to implement this enforcement at the application, middleware, or mediator level, as is done in Tivoli Privacy Manager[6] and the TIHI security mediator[20]. However, this approach leads to privacy leaks when applied to cell-level privacy enforcement, as discussed below.
There has been extensive research in the area of statistical databases motivated by the desire to provide statistical information (sum, count, etc.) without compromising individual information (see survey in [4]). It was also shown that one cannot provide high quality statistics and at the same time prevent partial disclosure of individual data. (It is assumed that additional mechanisms such as query admission control and audit trails [4] are in place to guard against the inference problem.)
Prior work in the area of data security can largely be grouped into the areas of discretionary access control, role-based access control, and mandatory access control [18]. Discretionary access control allows a database to grant and revoke access privileges to individual database users. In this case, the access control privileges typically refer to entire tables or views. Role-based access control allows a database to grant this type of privilege not to an individual user, but the user's group, or role [19]. In the mandatory access control model, there is a single set of rules governing access to the entire system, and individual users are not allowed to grant or revoke access privileges.
A well-known model of mandatory access control, the Bell-LaPadula model of multilevel secure databases, defines permissions in terms of objects, subjects, and classes [8]. Each object is a member of some class, for example “Top Secret,” “Secret”, and “Unclassified,” and in this model, the classes typically form a hierarchy. Multi-level databases also allow for the possibility of polyinstantiation, where there exist data objects that appear to have different values to users with different classifications [11]. These formalizations have been further refined by [14] and [15], and a schema decomposition allowing element-level classification to be expressed as tuple-level classification is described in [17].
Multi-level security has been implemented at the row level in several products, including Oracle 8i's “Row Level Security” (also known as “Virtual Private Database”) feature, which allows specification of security policies at the row level, and augments incoming queries with additional predicates to respect the security policy[1]. Work was done to benchmark row-level classification in multi-level secure database systems[13]. The notion of “reformulating” queries for security was also alluded to by[20], and [3] uses a query rewrite mechanism to control access to federated XML user-profile data.
In some ways, the limited disclosure problem can be viewed as an adaptation of the problems arising from multi-level and role-based access control. The problem considers the task of assigning (purpose, recipient) pairs (the subjects) access to data cells (objects), which are grouped into data categories (classes). The privacy problem requires an additional degree of flexibility, however, as data assigned to a particular category does not necessarily all have the same access semantics because of conditional rules, like opt-in and opt-out choices. This leads to more complex permissions management. However, the privacy problem also allows for an important key simplification—polyinstantiation of data need not be allowed.
The only known implementation of a DBMS with cell-level access control was done by SRI in the SeaView system [11], but a performance evaluation was never published. Several content-management applications have enforced fine-grained security by introducing an application layer that modifies queries with conditions that enforce access control policies, for example [16], but they are application-specific in their design and do not extend a DBMS for general use. The wide use of ine-grained security by applications offers additional evidence that extending a DBMS with this capability is overdue.
An ideal solution to the limited disclosure problem would flexibly protect data subject information without leaks, and would incur minimal privacy “checking” overhead when processing queries. Because of the time and expense required to modify existing application code, an ideal solution would require minimal change to existing applications.
It is accordingly an object of this invention to limit data disclosure in a software application, by enabling individual queries to respect data subjects' preferences and choices. The invention achieves this object by storing privacy semantics, classifying data items into categories, rewriting incoming queries to reflect stored privacy semantics, and masking prohibited values. In an exemplary embodiment, the software application is an unmodified database. The privacy semantics include individual data subject choices and privacy policies comprising rules describing authorized data recipients and authorized data access purposes. The privacy policies may require opt-in consent from data subjects for authorized data access, or may require opt-out consent from data subjects for data access to be denied. The masking is preferably performed at the individual cell level, and may employ a NULL value or another predetermined indicator value to denote a prohibited value.
The invention comprises a system, method, and computer program product that provides a high-performance cell-level solution to the limited disclosure problem by extending an application to support limited disclosure. Thus, the invention can be deployed to an existing environment without modification of existing applications.
The invention assigns each (purpose, recipient) pair a view over each database table, so that entire tuples and individual cells can have their own privacy semantics. In this embodiment, the purpose and recipient are inferred based on the application issuing the query. However, there are a multitude of alternative ways of defining and obtaining this information.
First, the limited disclosure problem is described as it relates to a relational database. Next, several limited disclosure models for relational data and their semantics are described. A basic implementation architecture for limited disclosure and some optimizations to this architecture are provided. Finally, the performance of the implementation is evaluated.
Limited Data Disclosure
One of the defining principles of data privacy, limited data disclosure, is based on the premise that data subjects should be given control over who is allowed to see their personal information, and under what circumstances. For example, patients entering a hospital must provide some information at the time of admission. The patient understands that this information may only be used under certain circumstances. The doctors may use the patient's medical history for treatment, and the billing office may use the patient's address information to process insurance claims. However, the hospital may not give patient address information to charities for the purpose of solicitation without consent.
Frequently, an organization will define a privacy policy describing such an agreement. Comprised of a set of rules, the privacy policy is a contract between the individual providing the information and the organization collecting the information. Data items are classified into categories. For simplicity these categories are assumed to be mutually exclusive. For each category of data, the rules in the privacy policy describe the class of individuals who may access the information (the recipients), and how the data may be used (the purposes). The policy may specify that the data items belonging to a category may be disclosed, but only with “opt-in” consent from the subject. The policy may also specify that data items belonging to a category will be disclosed unless the subject has specifically “opted-out” of this default. There is much existing work regarding electronic privacy policy definition[2][7][10].
A solution to the problem of limited disclosure would ensure that the rules contracted in these privacy policies are enforced. More specifically, each query issued to the database would be issued in conjunction with a particular purpose and recipient. The database would prohibit the outflow of data, except when the privacy policy includes a rule permitting disclosure of the data to the appropriate purpose and recipient. Similarly, the database should restrict modification of data according to privacy policies. In the hospital example, a query issued for the purpose of “solicitation” and recipient “external charity” would only reveal the personal information of those patients who provided consent.
Limitations of Tuple Level Enforcement
Consider a table containing patient information, as shown in
With row-level enforcement, clearly Alice's record should be visible to charities for solicitation, and Bob's record should be invisible. However, there is a problem with the records of Carl and David. In this case, one must either filter information that is actually permitted, or one must disclose information that is prohibited. In the following sections, three models of cell-level enforcement are described and then formally defined.
Strict Cell Level Enforcement
The above problem can be solved by defining a model of cell-level enforcement. One way of defining such a model would be to “mask” prohibited values using the NULL value. Each (purpose, recipient) is assigned a view of each table, T, in the database. Each view contains precisely the same number of tuples as the underlying table, but prohibited data elements are replaced with null. The view corresponding to the hospital example is given in
Table Semantics Limited Disclosure Model
The strict cell-level model is attractive because of its simplicity. However, if one wants the privacy enforced data tables to be consistent with the relational data model, one must also ensure that the primary key is never null.
For this reason, another cell-level model is defined, which is termed Table Semantics enforcement. Here, one assigns each (purpose, recipient) pair a view over each table in the database, and as before, prohibited cells are replaced with null values. However, in this case one allows both entire tuples and individual cells to have privacy semantics. The privacy semantics of the primary key are used to indicate the privacy semantics of the entire tuple. If the primary key is prohibited, then the entire tuple is prohibited. When this model is applied to a table, the result is that prohibited tuples are filtered from the result set, and then any remaining prohibited cells are replaced with the null value, as is done in[11]. The resulting table of patients from the hospital example is shown in
In SQL, NULL is a special value meant to denote “no value”[9]. Intuitively, it makes sense in the current problem to use null as a placeholder when a value is not available to a particular purpose and recipient. Adopting the semantics of SQL queries run against null values is desirable for several reasons:
Predicates applied to null values, such as X>null, will not evaluate to true. Because null values are defined this way, predicates applied to privacy enforced tables will behave as though the prohibited cells were not present.
Similarly, null values do not join with other values. Thus the results of a join query issued to one of the privacy enforced tables will produce results as if the null cells were not present. -Null values do not affect computation of aggregates, so an aggregate computed over a privacy enforced table is actually computed based only on the values available to the purpose and recipient.
There are some well-documented semantic anomalies inherent in the use of null values [9]. For example, the SQL expression AVG(Age) is not necessarily equal to the expression SUM(Age)/COUNT(*). An expression such as SELECT*FROM Patients WHERE AGE>50 OR AGE <=50, which might be expected to return all tuples in Patients, may not do so in the presence of nulls.
Replacing prohibited values with nulls makes some assumptions about the practical meaning of the null value. While it is not its intended use, in practice null may carry implied semantic meaning. In the hospital example, a null value in the Phone column may indicate that a patient has no phone. To alleviate this problem, one might consider defining a new data value, prohibited, carrying special semantics with regard to SQL queries, to act as a placeholder.
Query Semantics Limited Disclosure Model
The table semantics model defines a view of each data table for each (purpose, recipient) pair, based on the associated privacy semantics. These views combine to produce a coherent relational data model for each (purpose, recipient) pair, and queries are executed against the appropriate database version.
An alternative to this approach is to do enforcement based on the query itself. Unlike table semantics, here prohibited data is removed from a query's result set based on the purpose, recipient, and the query itself. This is termed the Query Semantics enforcement model. For example, using the hospital table, suppose one were to project the “Name” and “Age” columns from the Patients table. Using query semantics, the result of this query would be the table on the right of
This model benefits from the same properties of null values discussed above. However, these semantics cause some anomalies in certain cases. Queries may observe different numbers of records depending on the column(s) projected. For example, if the Salary attribute is provided based on a condition, and the Name attribute is provided unconditionally, projecting the Name column will likely obtain more records than projecting the Salary column. In some cases these slight semantic departures buy substantial performance gains, as shown in the experimental results, but the semantic tradeoff should be carefully considered.
Application-Level Limited Disclosure
There are several possible approaches to implementing application-level privacy enforcement. One such approach is to first retrieve the requested data from the database, and then apply the appropriate enforcement before returning the data to the user. In a cell-level enforcement scheme, this approach leads to significant difficulties.
For example, consider a query involving a predicate over a privacy-sensitive field: SELECT*FROM PATIENTS WHERE DISEASE=Hepatitis, and a patient who chose to disclose his name, but not his disease history. An application-level enforcement scheme might do the following to execute this query: First, the application would issue the query to the database, and retrieve the result set. Then, the application would go through each of the resulting records, and based on the privacy semantics, replace prohibited cells with null. However, this approach is flawed. In the previous example, the query results would contain the patient's records, with the Disease field blocked out. Unfortunately, this allows anyone to conclude from looking at the results that this patient has Hepatitis, even though he had chosen not to share this information. This type of leakage is not a problem in the table semantics or query semantics model because data values that are not visible to a particular purpose and recipient are removed prior to query execution.
An alternative approach might select all of the Patient data from the database (in this example, this would include all patient records, not just those with a particular disease), and apply the predicate in the application. However, this leads to significant performance problems as it must fetch data unnecessarily from the database. Query execution is more difficult yet when more complicated queries are considered, such as those involving aggregates or joins, because a significant amount of data must be extracted from the database, and then a large amount of the query processing must be performed at the application level.
Implementation Architecture
A database architecture for efficiently and flexibly enforcing limited disclosure rules is described below. The basic components of this architecture are the following:
Policy definition: Privacy policies must be expressed electronically, and stored in the database where they can be used to enforce limited disclosure.
Query modifier: SQL queries entering the database should be intercepted, and augmented to reflect the privacy semantics of the purpose and recipient issuing the query. The results of this new query will be returned to the issuer.
Privacy meta-data: This is where the additional information to determine the correct privacy semantics of an incoming query is stored.
Data and Choice Tables: The data is stored in relational tables in the database. User choices (opt-in and opt-out) must also be stored in the database.
In the prototype, privacy policies are defined using P3P [10], and the privacy meta-data is stored in the database as ordinary relational tables. The prototype enforcement module is implemented as an extension to the JDBC driver, where queries are intercepted and rewritten to reflect the privacy semantics stored in the privacy meta-data. In the implementation, queries are issued via an HTTP servlet, forcing the use of the secure driver.
There are two ways to determine the purpose and recipient associated with a query. The first possibility is to extend the syntax of an SQL query to include this information. For example, SELECT*FROM Patients FOR PURPOSE Solicitation RECIPIENT External_Charity. The second possibility is to infer this information based on the application context, similar to the approach implemented in [1]. Because the first method requires extensions to the query language and modification to existing applications, the second option is elected, though the rest of the implementation is compatible with either alternative. The query interceptor infers the purpose and recipient of the query based on the issuing application. The context of each application must be specified, and in the prototype, the context information is stored in an additional database table. This information is then used to tag incoming queries with the appropriate privacy semantics based on the issuing application.
An overview of this architecture is given in
Architecture Overview
The disclosure rules from a specified privacy policy are stored inside the database, as the Privacy Meta-data. These tables capture the purpose and recipient information, as shown in
In addition to storing the data disclosure rules, a mechanism for storing user choices must be provided. In the basic architecture, these values are stored in additional choice columns appended to the data tables themselves.
The basic enforcement mechanism intercepts and rewrites incoming queries to incorporate the privacy semantics stored in the privacy meta-data tables, as well as the user choices. The mechanism uses case-statements to resolve choices and conditions, and applies additional predicates to filter prohibited records from the result set. The query rewrite scheme is a straightforward SQL implementation of the enforcement definition.
Consider, for example, a data table Patients, containing an attribute Phone. Under the privacy policy that is in place, the Phone attribute is included in the Address category, which is made available to charities for the purpose of solicitation on an opt-in basis. The user choices for Address information are stored in column Choice—1. The choices for the primary key of the patients table, ID, are stored in column Choice—2. Suppose the following query is issued for this recipient and purpose:
SELECT Phone FROM Patients
This query can be rewritten to resolve this particular condition as follows, using the table semantics model:
SELECT
CASE WHEN Choice—1=1 THEN Phone ELSE null END
FROM Patients AS q1(Phone)
WHERE Choice—2=1
Similar rewriting techniques resolve the privacy semantics of both allowed and prohibited categories. The rewriting algorithm is given in
Implementing Enforcement Using Views
An alternative architecture becomes apparent in the case of table-semantics enforcement. In this case, it is possible to achieve the same enforcement using views, while circumventing the overhead of rewriting incoming queries. This simplifies the architecture greatly by capturing all of the information from the meta-data tables described in the previous architecture in a single table mapping (purpose, recipient) pairs to privacy views of each table, as shown in
These views may be constructed once at policy installation time, in which case there is no longer any need to store the privacy policy table or the category table. Alternatively, the invention may continue to store this information and lazily construct and cache these views as each is requested. In either case, the invention intercepts incoming queries, and based on the purpose and recipient information, redirects them to the appropriate view.
There is a complication to this approach when application queries with predicates over indexed data columns are considered. Consider for example the following query over a data table in which SSN is an indexed data value, and the disclosure of SSN is governed by some choice stored in Choice—2. Name is a non-indexed data value, and disclosure of Name is governed by Choice—1. For simplicity, primary-key based filtering is ignored in this example:
SELECT SSN, Name
FROM Participants
WHERE SSN=222-22-2222
In this case, the query is translated to:
SELECT SSN, Name
FROM (SELECT CASE WHEN CHOICE—2=1 THEN SSN ELSE null END,
CASE WHEN CHOICE—1=1 THEN Name ELSE null END
FROM Participants) AS q1(SSN, Name)
WHERE q1.SSN=222-22-2222
Unfortunately, executing this query in DB2 causes the index on SSN to be discarded because the reference to SSN is buried inside a case-statement. To fix this problem, the indexed data attribute and the corresponding choice can be pulled out to the predicate, where the index can more easily be applied:
SELECT SSN, Name
FROM (SELECT SSN,
CASE WHEN CHOICE—1=1 THEN Name ELSE null END,
Choice—2
FROM Participants) AS q1(SSN, Name, Choice—2)
WHERE q1.SSN=222-22-2222 AND q1.Choice—2=1
As this optimization is based on the query itself, it cannot be incorporated into the view definition without substantial additions to the database engine. The choice may only be pulled out to the predicate when the query includes a predicate on the particular attribute.
Alternative Rewrite Algorithm
An alternative to the case-statement rewrite mechanism implements the Table Semantics and Query Semantics enforcement models using the left outer join and full outer join operators respectively.
Consider the same query translated using the case-statement algorithm, with privacy semantics as described previously:
SELECT Phone FROM Patients
This query can be rewritten as follows to reflect the table semantics enforcement model:
(SELECT ID WHERE Choice—2=1) AS t1 (ID)
LEFT OUTER JOIN
(SELECT
ID, Phone WHERE Choice—1=1
FROM Patients AS q1 (Phone)
WHERE Choice—2=1) AS t2(ID, Phone)
ON t1.ID=t2.ID
The translation scheme for table semantics is an SQL implementation of the following relational algebra expression; the full SQL algorithm is omitted for brevity. Consider some query Q; each table T referenced by Q contains some attributes, a1 . . . an. For simplicity, assume these attributes belong to separate categories. Let k represent the primary key of T, and for simplicity assume that the primary key is comprised of just one column. Replace Q's reference to T with the following, where “∝” denotes the left outer join operator:
[σk=“Allowed”(Πk(T))]∝$I=$1[σa1=“Allowed”(Πk,a1(T))]∝$1=$1 . . . ∝$1=$1[σan=“Allowed”(Πk,an(T))]
A similar scheme is provided for query semantics. Consider a query Q which projects a set of columns from some set of tables. For each such table T, let p1 . . . pn denote the columns of T projected by Q, and let k be the primary key of T. Again, assume each category contains just one column, and the primary key contains just one column. The scheme replaces the reference to T by Q with the following, where “x” denotes the full outer join operator:
[σp1=“Allowed”(Πk,p1(T))]×$1=$1[σp2=“Allowed”(Πk,p2(T))]×$1=$1v$3=$1 . . . ×$1=$1v$3=$1v . . . [σan=“Allowed”(Πk,an(T))]
It is worth noting that in DB2 the outer join rewrite algorithm cannot be applied to queries of the form “SELECT FOR UPDATE” because of the join operators involved. This is similar to the fact that, in general, views joining multiple tables are not updatable. However, in this case, there is a straightforward translation from the view update to a table update, so in the future the database system could be extended to handle this situation.
The SeaView system took a similar approach in constructing cell-level access control [11]. In the SeaView system, multilevel relations existed only at the logical level, as views of the data. They were actually decomposed into a collection of single-level tables, which were physically stored in the database. The multi-level relations were recovered from the underlying relations using the left outer join and union operators. However, there are important performance implications in choosing to use an outer join rewrite algorithm for limited disclosure, as discussed below.
PERFORMANCE EVALUATION: Extensive experiments were performed to study the performance of the invention and of query modification as methods of enforcing limited disclosure. The experiments are intended to address the following key questions:
Overhead of Privacy Enforcement: What is the overhead cost introduced by privacy checking? This question is addressed through an experiment that factors out the impact of choice selectivity. In the worst case, the cost of checking privacy semantics is incurred, but no performance gain by filtering prohibited tuples from the result set is seen.
Scalability: The scalability of the rewrite scheme is tested in terms of database size and application selectivity. Both the percentage of users who elect to share their data for a particular purpose and recipient (choice selectivity), and the percentage of the records selected by an issued query (application selectivity) are varied.
Except where otherwise noted, the experiments use cell-level enforcement, but make the simplifying assumption that access to all columns in the data table is based on a single opt-in/opt-out choice. This means that every record is either fully visible or fully invisible; however, for the case-statement rewrite mechanism cell-level enforcement is still performed by evaluating a case statement over each column. In the table semantics model, this assumption does not influence execution time. If the primary key is allowed, then the tests fetch the tuple and process a case statement for each cell. For the query semantics model, the number of independent “optable” columns only influences performance insofar as it influences the number of tuples retrieved, so it is possible to assess the performance of “multi-category” tables using a single category evaluation. The number of independent data categories in a table does influence the performance of the outer join algorithm, as it dictates the number of joins necessary.
Impact of Filtering: In both the table and query semantics models, there are cases where tuples are filtered entirely from the result set of a query. An experiment is performed to show the impact of this filtering.
Enforcement Model: The performance implications of choosing the Table Semantics or Query Semantics enforcement model are studied.
Rewrite Algorithms—Case vs. Outer Join: The performance of the case-statement and the outer join rewrite algorithms are briefly compared.
Views vs. Complete Query Rewrite: The tradeoff between defining and caching privacy views and performing complete query rewrite for table semantics enforcement are discussed. The cost of completely rewriting queries in a Java prototype implementation is measured. The implications of materializing the privacy-preserving view are also discussed.
Choice Storage: The implications of choosing among the various modes of choice storage are discussed.
There are several distinct sources of performance cost in the embodiment, which were isolated in the performance experiments.
Query Rewrite: The invention intercepts and rewrites queries. This component includes indexed lookup queries to the privacy meta-data. The cost of rewriting a query is constant in the number of columns and categories in the underlying table schema, and relatively small compared to the cost of executing the queries themselves.
Query Execution: The cost of executing the rewritten query includes some amount of I/O, CPU processing, and the cost of returning the resulting data to the application.
Experimental Setup
The performance of the invention was measured using a synthetically-generated dataset, based on the Wisconsin Benchmark[12]. The synthetic data schema is described in
The DB2batch utility measured the cost of executing queries. Each query was run 6 times, flushing the buffer pool, query cache, and system memory between unique queries. The results given below represent the warm performance numbers, the average of the last 5 runs of each query. The size of the data table is 5 million records, except where otherwise noted.
Experimental Results and Analysis
Overhead and Scalability
The first set of experiments measures the overhead cost of performing privacy enforcement and the scalability of the invention to large databases. To measure this cost, simple selection queries are considered, with predicates applied to non-indexed data columns. Results are reported for the table semantics privacy enforcement model, but the trends are similar for query semantics. It is assumed, as described previously, that all columns in the table belong to a single data category, with a single choice value. To measure the overhead cost of enforcement, the worst case scenario is considered as described above, where the choice selectivity is 100%, so all the cost of privacy processing is incurred, but the performance gains of filtering are not seen.
Because the figures show the warm performance numbers, the results of queries over the 1 million-tuple table can largely be processed from the buffer pool. In the case of the 10 million-tuple table, however, the size of the table exceeds the size of the buffer pool and the query processing incurs disk I/O. Thus, in the case of the former, the cost is dominated by the CPU time spent processing the case statements, whereas in the latter, the cost is dominated by I/O. As the application filters fewer tuples, the CPU cost increases, but because the queries are executed as sequential scans, the I/O cost does not change, explaining
Implications of Filtering due to Choice Selectivity
In cases with choice selectivity less than 100%, the rewritten queries perform significantly better because, through the use of a choice index, they need to read fewer tuples. In this experiment, the application query selects all 5 million records in the table. However, the rewritten queries vary the choice selectivity. Note that in this experiment, the queries with a choice selectivity of 0.01, 0.1, and 0.5 used the index on the choice column; the others did not.
As can be seen from
Performance Differences Among Enforcement Models
There is a clear performance distinction between the table semantics and the query semantics privacy models, which becomes clear when a table comprised of columns belonging to different data categories, with independent privacy rules, is considered.
In the table semantics model, a tuple is filtered from the result set if the primary key is forbidden. In this case, if the underlying table schema is defined as suggested above, and a record is made visible if any of its attributes are visible, then it is convenient to think of the independent choice selectivities for all of the projected columns combining to form the effective choice selectivity. When considering some table, T, containing x categories, such that the choice selectivities for the categories are independent of one another, the effective selectivity can be determined by
1−Πi=1x(1−si)
where si is the choice selectivity corresponding to category i. This is not the case when the query semantics model is considered. Here, the effective choice selectivity is not determined by the underlying table schema; instead it is determined by the selectivities of only those columns projected by the query. In many situations, this leads to substantial performance gain, as fewer tuples need to be read and returned.
However, in some situations, this performance gain may be offset because the query semantics rewrite algorithm yields a query that is less likely to use indices on the choice columns. For instance, if the query projects two columns belonging to two separate categories, in the query semantics model, the filtering predicate might include a disjunction of the form, WHERE Choice—0=1 OR Choice—1=1. It was observed that when executing the above predicate, the optimizer does not make use of the indices on either Choice—0 or Choice—1 even though the combined selectivity of the two choices is low. It is possible that the choice indexes were not incorporated in the query plan because of the disjunction in the predicate.
Comparing Rewrite Algorithms
In most situations, the case-statement rewrite algorithm substantially outperforms the outer-join rewrite algorithm, and for good reason. The outer join algorithm scales poorly because of the repeated and costly join operations involved. For large tables with high choice selectivity (many tuples selected), the performance was quite poor, so these results are omitted.
However, there are some specific situations where the outer join algorithm does perform better than using case-statements. For example, in the previous section it was observed that the DB2 optimizer did not use choice indexes for a query with a predicate including a disjunction of conditions. However, the outer join rewriting algorithm was more likely to be able to use such indexes.
Query Rewriting vs. Views
As shown above, it is possible to implement a table semantics enforcement mechanism by redirecting incoming queries to predefined privacy views, rather than entirely rewriting the incoming queries. In practice, these two methods yield identical query execution performance, except when additional rewriting must be performed to avoid discarding a useful index, as explained above. In this case, the performance impacts of not using an index may be substantial.
The views implementation avoids much of the cost of rewriting queries to reflect the privacy semantics. However, this cost is constant in the number of columns, and for large tables and complex queries, small compared to the cost of executing the queries themselves. The cost of querying the privacy meta-data is negligible because these queries are implemented as simple indexed lookups. For eight columns, from distinct data categories, the average time to rewrite a query in the Java implementation averaged approximately 0.15 seconds when the privacy meta-data connections were pooled.
An alternative, feasible only as a method of optimizing performance for a few (purpose, recipient) pairs, is actually materializing the view. Querying the materialized view is very inexpensive, as shown in
Limited disclosure is a vital component of a data privacy management system. Several models for limited disclosure in a relational database are presented, along with a proposed scalable architecture for enforcing limited disclosure rules at the database level. Application-level solutions are inefficient and unable to process arbitrary SQL queries without leaking private information. By pushing the enforcement down to the database, improved performance and query power are gained without modification of existing application code.
The performance overhead of privacy enforcement is small and scalable, and often the overhead is more than offset by the performance gains obtained through tuple filtering. Queries run on tables that are sparse due to many values being masked to limit data disclosure may execute significantly faster than usual, so query optimization methods may be substantially more effective when they consider data that has been masked.
A general purpose computer is programmed according to the inventive steps herein. The invention can also be embodied as an article of manufacture—a machine component—that is used by a digital processing apparatus to execute the present logic. This invention is realized in a critical machine component that causes a digital processing apparatus to perform the inventive method steps herein. The invention may be embodied by a computer program that is executed by a processor within a computer as a series of computer-executable instructions. These instructions may reside, for example, in RAM of a computer or on a hard drive or optical drive of the computer, or the instructions may be stored on a DASD array, magnetic tape, electronic read-only memory, or other appropriate data storage device.
While the particular SYSTEM AND METHOD FOR LIMITING DISCLOSURE IN HIPPOCRATIC DATABASES as herein shown and described in detail is fully capable of attaining the above-described objects of the invention, it is to be understood that it is the presently preferred embodiment of the present invention and is thus representative of the subject matter which is broadly contemplated by the present invention, that the scope of the present invention fully encompasses other embodiments which may become obvious to those skilled in the art, and that the scope of the present invention is accordingly to be limited by nothing other than the appended claims, in which reference to an element in the singular is not intended to mean “one and only one” unless explicitly so stated, but rather “one or more”. All structural and functional equivalents to the elements of the above-described preferred embodiment that are known or later come to be known to those of ordinary skill in the art are expressly incorporated herein by reference and are intended to be encompassed by the present claims. Moreover, it is not necessary for a device or method to address each and every problem sought to be solved by the present invention, for it to be encompassed by the present claims. Furthermore, no element, component, or method step in the present disclosure is intended to be dedicated to the public regardless of whether the element, component, or method step is explicitly recited in the claims. No claim element herein is to be construed under the provisions of 35 U.S.C. 112, sixth paragraph, unless the element is expressly recited using the phrase “means for”.
[20] G. Wiederhold, M. Bilello, V. Sarathy, and X. Qian. A Proceedings of the 1996 AMIA Conference, security mediator for healthcare information. In Washington, D.C., October 1996.