1. Field of the Invention
This invention relates in general to database management systems performed by computers, and in particular, to querying encrypted data in a relational database system.
2. Description of Related Art
(Note: This application references a number of different publications, as indicated throughout the specification by one or more reference numbers. A list of these different publications ordered according to these reference numbers can be found below in the section entitled “References.” Each of these publications is incorporated by reference herein.)
The Internet has made it possible for all computers to be connected to one another. The influence of transaction-processing systems and the Internet ushered in the era of e-business. The Internet has also had a profound impact on the software industry. It has facilitated an opportunity to provide software usage over the Internet, and has led to a new category of businesses called “application service providers” or ASPs.
ASPs provide worldwide customers the privilege to use software over the Internet. ASPs are staffed by experts in the art of putting together software solutions, using a variety of software products, for familiar business services such as payroll, enterprise resource planning, and customer-relationship marketing. ASPs offer their services over the Internet to small and large worldwide organizations. Since fixed costs are amortized over a large number of users, there is the potential to reduce the service cost even after possibly increased telecommunications overhead.
It is possible to provide storage and file access as services. The natural question is the feasibility of providing the next value-add layer in data management. From the business perspective, database as a service inherits all the advantages of the ASP model, indeed even more, given that a large number of organizations have their own database management systems (DBMSs). The model allows organizations to leverage hardware and software solutions provided by the service providers, without having to develop them on their own. Perhaps more importantly, it provides a way for organizations to share the expertise of database professionals, thereby cutting the people cost of managing a complex information infrastructure, which is important both for industrial and academic organizations [15].
From the technological angle, the model poses many significant challenges foremost of which is the issue of data privacy and security. In the database-service-provider model, user data resides on the premises of the database-service provider. Most corporations view their data as a very valuable asset. The service provider would need to provide sufficient security measures to guard data privacy.
At least two data-privacy challenges arise. The first challenge is: how do service providers protect themselves from theft of customer data from hackers that break into their site and scan disks? Encryption of stored data is the straightforward solution, but not without challenges. Trade-offs need to be made regarding encryption techniques and the data granularity for encryption.
This first challenge was examined by Hacigümüs, et al. [6]. It was found that hardware encryption is superior to software encryption. Encrypting data in bulk reduced the per-byte encryption cost significantly, exposing to startup overheads. Encrypting by row was found preferable to encrypting by field for queries from the TPC-H benchmark [14].
The second challenge is that of “total” data privacy, which is more complex since it includes protection from the database provider. The requirement is that encrypted data may not be decrypted at the provider site. A straightforward approach is to transmit the requisite encrypted tables from the server (at the provider site) to the client, decrypt the tables, and execute the query at the client. But, this approach mitigates almost every advantage of the service-provider model, since now primary data processing has to occur on client machines. It will become clear later, for a large number of queries such as selections, joins, and unions, much of the data processing can be done at the server, and the answers can be computed with little effort by the client.
What is needed in the art are servers, hosted by the service provider, that store encrypted databases, and clients that can access and decrypt the encrypted databases. Further, there is need for a certain amount of query processing to occur at the server without jeopardizing data privacy. While data privacy is paramount, there is also a need for adequate performance of any queries performed by the servers. The present invention satisfies these needs.
There is previous work in different research areas, some of which are related to the present invention. Search on encrypted data [2], where only keyword search is supported, and doing arithmetic over encrypted data [10] have been studied in the literature. However, functionalities provided by those are very limited and insufficient in executing complex SQL queries over encrypted data.
To overcome the limitations in the prior art described above, and to overcome other limitations that will become apparent upon reading and understanding the present specification, the present invention discloses a client-server relational database system, wherein data from the client computer is encrypted and hosted by the server computer, the encrypted data is operated upon by the server computer, using one or more operators selected from a group of operators comprising: (a) inequality logic operators, (b) aggregation operators, and (c) wildcard matching operators, to produce an intermediate results set, the intermediate results set is sent from the server computer to the client computer, and the intermediate results set is decrypted and filtered by the client computer to produce actual results. The group of operators is limited because the encrypted results set, when decrypted, includes inaccuracies therein. The client computer applies a set of correction procedures to the decrypted results set to remove the inaccuracies therein.
Referring now to the drawings in which like reference numbers represent corresponding parts throughout:
a)-(d) illustrate an original query tree, replacing encrypted relations, doing selection at the server, and multiple interactions between the client and server;
a)-(b) illustrate an original query tree, and after replacing with encrypted relations;
a)-(d) illustrate an original query tree after rewriting selections, after pulling selections, after rewriting join; and a final query tree;
a)-(d) illustrate an original query tree with join computation at the server, rewriting a difference operator using outerjoin; after pulling selections and projections, and a final query tree;
a)-(d) illustrate alternative query plans for a reduced maybe set; and
In the following description of the preferred embodiment, reference is made to the accompanying drawings, which form a part hereof, and in which is shown by way of illustration a specific embodiment in which the invention may be practiced. It is to be understood that other embodiments may be utilized and structural and functional changes may be made without departing from the scope of the present invention.
1. Overview
In this illustration, there are three fundamental entities. A client computer 100 encrypts data and stores the encrypted data at a server computer 102 in an encrypted client database 104 managed by an application service provider 106. The encrypted client database 104 is augmented with additional information (which we call the index) allows certain amount of query processing to occur at the server computer 102 without jeopardizing data privacy. The client computer 100 also maintains metadata 108 which is used by a query translator 110 for translating the user query 112 into different portions, i.e., a query over encrypted data 114, for execution on the server computer 102, and a query over decrypted data 116, for execution on the client computer 100. The server computer 102 generates an encrypted intermediate results set 118, which is provided to the client computer 100 and stored as temporary results 120. The client computer 100 includes a query executor 122 that decrypts the temporary results 120 and performs the query over decrypted data 116 in order to generate actual results 124 for display 126 to the user.
Specifically, data from a client computer 100 is encrypted by the client computer and hosted by a server computer 102, the encrypted data is operated upon by the server computer 102, using one or more operators selected from a group of operators comprising: (a) inequality logic operators, (b) aggregation operators, and (c) wildcard matching operators, to produce an encrypted intermediate results set 118, the encrypted intermediate results set 118 is sent from the server computer 102 to the client computer 100, and the intermediate results set 118 is decrypted and filtered by the client computer 100 to produce actual results. In this logic, the group of operators is limited because the encrypted intermediate results set 118, when decrypted, includes inaccuracies therein. Moreover, the client computer 100 applies a set of correction procedures to the decrypted intermediate results set 118 to remove the inaccuracies therein.
In this environment the client computer 100 maintains the needed encryption key(s), and the data is encrypted by the client computer 100 before it is sent to the server computer 102 for inclusion in the encrypted client database 104. Consequently, the data is always encrypted when it is stored on or processed by the server computer 102. Moreover, at no time are the encryption keys given to the server computer 102, and thus the data can never be decrypted by the server computer 102.
2. Relation Encryption And Storage Model
Before we discuss techniques for query processing over encrypted data, let us first discuss how the encrypted data is stored at the server.
For each relation R(A1, A2, . . . , An), we store on the server an encrypted relation:
RS(etuple,A1S,A2S, . . . ,AnS)
where the attribute etuple (We will explain how etuple is defined in Section 2.4.) stores an encrypted string that corresponds to a tuple in relation R. (Note that we could alternatively have chosen to encrypt at the attribute level instead of the row level. Each alternative has its own pros and cons. We point the interested readers to [6] for a detailed description. The rest of this paper assumes encryption is done at the row level.)
Each attribute AiS corresponds to the index for the attribute Ai that will be used for query processing at the server. For example, consider a relation emp shown in Table 1 that stores information about employees:
The emp table is mapped to a corresponding table at the server:
empS(etuple,eidS,enameS,salaryS,addrS,didS)
It is only necessary to create an index for attributes involve in search and join predicates. In the above example, if we knew that there would be no query that involves attribute addr in either a selection or a join, then the index on this attribute need not be created. Without loss of generality, we assume that an index is created over each attribute of the relation.
2.1 Partition Functions
We explain what is stored in attribute AiS of RS for each attribute Ai of R. For this purpose, we will need to develop some notations. We first map the domain of values (Di) of attribute R.Ai into partitions {p1, . . . ,pk}, such that (1) these partitions taken together cover the whole domain; and (2) any two partitions do not overlap. Formally, we define a function partition as follows:
partition(R.Ai)={p1,p2, . . . ,pk}
As an example, consider the attribute eid of the emp table above. Suppose the values of domain of this attribute lie in the range [0,1000]. Assume that the whole range is divided into 5 partitions: [0,200], (200,400], (400,600], (600,800], and (800,1000]. (Note that it is not necessary to create all of the partitions at the beginning; instead, they can be created as the values are inserted into the database.)
That is:
partition(emp.eid)={[0,200],(200,400],(400,600],(600,800],(800,1000]}
Different attributes may be partitioned using different partition functions. It should be clear that the partition of attribute Ai corresponds to a splitting of its domain into a set of buckets. Any histogram-construction technique, such as MaxDiff, equi-width, or equi-depth [9], could be used to create partitioning of attributes. In the examples used to explain our strategy, for simplicity, we will assume the equi-width partitioning. Extension of our strategy to other partitioning methods is relatively straightforward, though it will require changes to some of the notations developed. For example, unlike equi-width case where a value maps to only a single histogram bin, in equi-depth it may map to multiple buckets. Our notation assumes that each value maps to a single bucket. In the experimental section, besides using the equi-width we will also evaluate our strategy under the equi-depth partitioning.
In the above example, an equi-width histogram was illustrated. Note that when the domain of an attribute corresponds to a field over which ordering is well defined (e.g., the eid attribute), we will assume that a partition pi is a continuous range. We use pi.low and pi.high to denote the lower and upper boundary of the partition, respectively.
2.2 Identification Functions
Furthermore, we define an identification function called ident to assign an identifier identR.A
The ident function value for a partition is unique, that is, identR.A
2.3 Mapping Functions
Given the above partition and identification functions, we define a mapping function MapR.A
In the example above, the following Table 2 shows some values of the mapping function for attribute emp.eid. For instance, Mapemp.eid(23)=2, Mapemp.eid(860)=4, and Mapemp.eid(875)=4.
We further classify two types of mapping functions:
1. Order preserving: A mapping function MapR.A
2. Random: A mapping function is called random if it is not order preserving.
A random mapping function provides superior privacy compared to its corresponding order-preserving mapping. However, as we will see later, whether a mapping function is order preserving or not affects how we translate a query into queries on the client and server. Query translation is simplified using a order-preserving mapping function. We will develop translation strategies for both types of mapping functions.
We further define three more mapping functions that will help us in translating queries over the encrypted representation. While the first function defined holds over any attribute, the latter two hold for the attributes whose domain values exhibit total order. Application of the mapping function to a value v, greater than the maximum value in the domain, vmax, returns MapR.A
Let S be a subset of values in the domain of attribute Ai, and v be a value in the domain. We define the following mapping functions on the partitions associated with Ai:
MapR.A
MapR.A
MapR.A
Essentially, MapR.A
2.4 Storing Encrypted Data
We now have enough notations to specify how to store the encrypted relation RS on the server. For each tuple t=a1, a2, . . . , an in R, the relation RS stores a tuple:
encrypt({a1,a2, . . . , an}),MapR.A1(a1),MapR.A2(a2), . . . , MapR.An(an)
where encrypt is the function used to encrypt a tuple of the relation. For instance, the following Table 3 is the encrypted relation empS stored on the server:
The first column etuple contains the string corresponding to the encrypted tuples in emp. For instance, the first tuple is encrypted to “1100110011110010 . . . ” that is equal to encrypt(23, Tom, 70K, Maple, 40). The second is encrypted to “1000000000011101 . . . ” equal to encrypt(860, Mary, 60K, Main, 80). We treat the encryption function as a black box in our discussion. Any block cipher technique such as AES [1], RSA [11], Blowfish [12], DES [3] etc., can be used to encrypt the tuples.
The second column corresponds to the index on the employee ids. For example, value for attribute eid in the first tuple is 23, and its corresponding partition is [0,200]. Since this partition is identified to 2, we store the value “2” as the identifier of the eid for this tuple. Similarly, we store the identifier “4” for the second employee id 860. In the table above, we use different mapping functions for different attributes. The mapping functions for the ename, salary, addr, and did attributes are not shown, but they are assumed to generate the identifiers listed in the table.
In general, we use the notation “E” (“Encrypt”) to map a relation R to its encrypted representation. That is, given relation R(A1, A2, . . . , An), relation E(R) is RS(etuple, A1S, A2S, . . . , AnS). In the above example, E(emp) is the table empS.
2.5 Decryption Functions
Given the operator E that maps a relation to its encrypted representation, we define its inverse operator D that maps the encrypted representation to its corresponding unencrypted representation. That is, D(RS)=R. In the example above, D(empS)=emp. The D operator may also be applied on query expressions. A query expression consists of multiple tables related by arbitrary relational operators (e.g., joins, selections, etc.)
As it will be clear later, the general schema of an encrypted relation or the result of relational operators amongst encrypted relations, RiS is:
R1S.etuple,R2S.etuple, . . . , R1S.A1S,R1S.A2S, . . . , R2S.A1S,R2S.A2S, . . .
When the decryption operator D is applied to RiS, it strips off the index values (R1S.A1S, R1S.A2S, . . . , R2S.A1S, R2S.A2S, . . . ) and decrypts (R1S.etuple, R2S.etuple, . . . ) to their unencrypted attribute values.
As an example, assume that another table defined as mgr (mid, did) was also stored in the database. The corresponding encrypted representation E(mgr) will be a table mgrS (etuple, midS, didS). Suppose we were to compute a join between tables empS and mgrS on their didS attributes. The resulting relation tempS will contain the attributes empS.etuple, eidS, enameS, salaryS, addrS, empS.didS, mgrS.etuple, midS, mgrS.didS. If we are to decrypt the tempS relation using the D operator to compute D(tempS), the corresponding table will contain the attributes
(eid,ename,salary,addr,emp.did,mid,mgr.did)
That is, D(tempS) will decrypt all of the encrypted columns in tempS and drop the auxiliary columns corresponding to the indices.
3. Mapping Conditions
In this section, we study how to translate specific query conditions in operations (such as selections and joins) to corresponding conditions over the server-side representation. This translation function is called Mapcond. Once we know how conditions are translated, we will be ready to discuss how relational operators are translated over the server-side implementation, and how query trees are translated.
For each relation, the server side stores the encrypted tuples, along with the attribute indices determined by their mapping functions. Meanwhile, the client stores the meta data about the specific indices, such as the information about the partitioning of attributes, the mapping functions, etc. The client utilizes this information to translate a given query Q to its server-side representation QS, which is then executed by the server. We consider query conditions characterized by the following grammar rules:
In the discussion below we will use the following tables to illustrate the translation.
emp(eid, ename, salary, addr, did, pid)
mgr(mid, did, mname)
proj(pid, pname, did, budget)
Attribute=Value: Such a condition arises in selection operations. The mapping is defined as follows:
Mapcond(Ai=v)AiS=MapA
As defined in Section 2.3, function MapA
(eid=860)eidS=4
since eid=860 is mapped to 4 by the mapping function of this attribute.
Attribute <Value: Such a condition arises in selection operations. The attribute must have a well defined ordering over which the “<” operator is defined. Depending upon whether or not the mapping function MapA
For instance, the following condition is translated:
Mapcond(eid<280)eidSε{2,7}
since all employee ids less than 280 have two partitions [0,200] and (200,400], whose identifiers are {2,7}.
Attribute >Value: This condition is symmetric with the previous one. As before we differentiate whether or not the mapping function is order preserving. The translation is as follows:
For instance, the following condition is translated:
Mapcond(eid>650)eidSε{1,4}
since all employee ids greater than 650 are mapped to identifiers: {1,4}
Attribute1=Attribute2: Such a condition might arise in a join. The two attributes can be from two different tables, or from two instances of the same table. The condition can also arise in a selection, and the two attributes can be from the same table. The following is the translation:
where φ is pkεpartition(Ai), piεpartition(Aj), pk∩pi≠Ø. That is, we consider all possible pairs of partitions of Ai and Aj that overlap. For each pair (pk, pl), we have a condition on the identifiers of these two partitions: AiS=identA
For instance, Table 4 above shows the partition and identification functions of two attributes emp.did and mgr.did. Then condition emp.did=mgr.did is translated to the following condition C1:
C1: (empS.didS=2mgrS.didS=9)(empS.didS=4mgrS.didS=9)(empS.didS=3mgrS.didS=8)(empS.didS=1mgrS.didS=8)
Attribute1<Attribute2: Again such a condition might arise in either a join or in a selection. Let us assume that the condition is Ai<Aj. Just as in translating conditions with inequality operator seen previously, the mapping of the condition depends upon whether or not the mapping functions of the attributes Ai and Aj are order preserving or random. We specify the translation for each in turn.
where φ is pkε(partition(Ai), plεpartition(Aj).
where φ is pkεpartition(Ai), plεpartition(Aj), pl.high≧pk.low. That is, we consider all pairs of partitions of Ai and Aj that could satisfy the condition. For each pair, we have a condition corresponding to the pair of their identifiers. We take the disjunction of these conditions.
For example, condition C2: emp.did<mgr.did is translated to:
C2: empS.didS=2mgrS.didS=9)empS.didS=2mgrS.didS=8)empS.didS=4mgrS.didS=9)empS.didS=4mgrS.didS=8)empS.didS=3mgrS.didS=8)empS.didS=1mgrS.didS=8)
Condition empS.didS=4mgrS.didS=9 is included, since partition (100,200] for attribute emp.did and partition (200,400] for attribute mgr.did can provide pairs of values that satisfy emp.did<mgr.did.
For condition Attribute1>Attribute2, the mapping is same as the mapping of Attribute2<Attribute1, as described above with the roles of the attributes reversed.
Condition1Condition2, Condition1Condition2: The translation of the two composite conditions is given as follows:
Mapcond(Condition1Condition2)Mapcond(Condition1)Mapcond(Condition2)
Mapcond(Condition1Condition2)Mapcond(Condition1)Mapcond(Condition2)
Translation of Mapcond(Condition) treatment is more involved since negated queries are not monotonic and their correct translation requires more notation. This discussion can be found in [5].
Operator ≦ follows the same mapping as < and operator ≧ follows the same mapping as >. Conditions that involve more than one attribute and operator are not discussed.
4. Implementing Relational Operators Over Encrypted Relations
In this section, we describe how individual relational operators (such as selections, joins, set difference, and grouping operators) can be implemented in the proposed database architecture. Our strategy is to partition the computation of the operators across the client and the server. Specifically, we will attempt to compute a superset of answers generated by the operator using the attribute indices stored at the server. These answers will then be filtered at the client after decryption to generate the true results. We will attempt to minimize the work done at the client as much as possible. Furthermore, we will try to ensure as much as possible that operators executed on the client side are such that they can be applied to the tuples arriving over the answer stream as soon as they arrive (without a need to store them). The purpose is to guarantee that the client-side operators can be efficiently implemented. The implementation of operators developed in this section will be used in the following section, where we develop an algebraic framework for rewriting SQL queries for the purpose of splitting the query computation across the client and the server.
For explaining the implementation of operators, we will consider the following two simplified relations of those in the previous section:
emp(eid, did), mgr(mid, did)
In the previous sections, we have given the Map functions of emp.eid, emp.did, and mgr.did. For simplicity, we assume that the Map function of mgr.mid is the same as that of emp.eid, as shown in
The Selection Operator (σ): Consider a selection operation σC(R) on a relation R, where C is a condition specified on one or more of the attributes A1, A2, . . . , An of R. A straightforward implementation of such an operator in our environment is to transmit the relation RS from the server to the client. Then the client decrypts the result using the D operator, and implements the selection. This strategy, however, pushes the entire work of implementing the selection to the client. In addition, the entire encrypted relation needs to be transmitted from the server to the client. An alternative mechanism is to partially compute the selection operator at the server using the indices associated with the attributes in C, and push the results to the client. The client decrypts the results and filters out tuples that do not satisfy C. Specifically, the operator can be rewritten as follows:
σC(R)=σC(D(σMap
In the above notation, we adorn the operator that executes at the server with a superscript “S” to highlight the fact that the select operator executes at the server. All non-adorned operators are assumed to execute at the client. The decryption operator D will only keep the attribute etuple of RS, and drop all the other AiS attributes. We explain the above implementation using an example σeid<395did=140(emp). Based on the definition of Mapcond(C) discussed in the previous section, the above selection operation will be translated into σC(D(σC′S(empS))), where the condition C′ on the server is:
C′=Mapcond(C)=(eidSε[2,7]didS=4)
The Join Operator (): Consider a join operation
The join condition C could be either equality conditions (in which case the join corresponds to an equijoin), or could be more general conditions (resulting in theta-joins). The above join operation can be implemented as follows:
As before, the S adornment on the join operator emphasizes the fact that the join is to be executed at the server. For instance, join operation
is translated to:
where the condition C′ on the server is condition C1 defined in Section 3.
The Grouping and Aggregation Operator (γ): A grouping and aggregation operation is denoted by γL(R), where L=LG∪LA.LG refers to a list of attributes on which the grouping is performed, and LA corresponds to a set of aggregation operations. As an example, the operation γC,COUNT(B)→F(R) means that we create groups using attribute C of relation R, and for each group compute the count(B) function. That is, LG={C}, and LA={COUNT(B)→F}. The resulting relation will contain two attributes C and F. A tuple in the result will have an entry for each distinct value of C, and the number of tuples in the group reported as attribute F. If LA=Ø, only grouping is performed.
Implementation of the grouping operator γL(R) can be achieved as follows:
γL(R)=γL(D(γL′S(RS))), where L′={AiS|AiεLG}
That is, the server will group the encrypted tuples based on the attributes of LG. The server does not perform any aggregation corresponding to LA, since it does not have any values for those attributes in LA. The results of γL′S are returned to the client, which performs the grouping operation γL. This operation can be implemented very efficiently, since every tuple belonging to a single group of γL will be in a single γL′S group computed by the server. As a result, the client only needs to consider tuples in a single γL′S group when computing the groups corresponding to γL. Of course, the aggregation functions specified in LA will be computed at the client, since their computation requires that tuples be first decrypted.
We explain the implementation using the example below.
γdid,COUNT(eid)→F(emp)
That is, we want to find the number of employees in each department. Let L denote “did, COUNT(eid)→F.” The operation is translated to:
γL(D(γdid
That is, we first do a grouping on the didS attribute on the server. After the grouped tuples are returned to the client, we decrypt the data, and perform the grouping operation on the did attribute. This step can be done efficiently, since all the tuples with the same did have already been grouped by the server. Finally, we perform the aggregation count(eid) to count the number of employee ids for each did.
The Sorting Operator (τ): A sorting operation τL(R) can be implemented similarly to the grouping operator. That is, we first sort on partition ids at the server. The strategy to implement τL(R) is as follows:
τL(R)=τL(D(γL′S(RS)))
where L′=list of AiS corresponding to the Ai in the list L of attributes.
That is, we do a grouping operation γL′S on the encrypted attributes L′ of those in L. If the mapping functions of the attributes in L are all order preserving, this grouping γL′S operation can be replaced by a corresponding sorting operation τL′S. After the results are returned to the client, we call the decryption function D, and perform the τL operation by sorting the tuples on attributes L.
Note that the amount of work done at the client to compute τL in postprocessing depends upon whether or not the attributes listed in L have order-preserving mappings. If the attributes have order-preserving mappings, then the results returned by the server are presorted up to within a partition. Thus, sorting the results is a simple local operation over a single partition. Alternatively, even if the mapping is not order preserving, it is useful to compute γS at the server to reduce the amount of client work. Since the tuples have been grouped by the server, τL can be implemented efficiently using a merge-sort algorithm.
For example, the sorting operation τeid(emp) can be implemented as follows:
τeid(D(γeidS(empS)))
where L={eid}. That is, we first perform a grouping operation γeid on the empS relation on the server. The client decrypts the returned tuples, and applies the sorting operation τemp.
The Duplicate-Elimination Operator (δ): The duplicate-elimination operator δ is implemented similarly to the grouping operator:
δ(R)=δ(D(γL(RS)))
where L=list of all attributes AiS where Ai is an attribute in R.
That is, we first group the encrypted tuples on the server using all the attributes in RS. After the results are returned and decrypted at the client, we perform the duplicate elimination operation δ. For example, the operation δ(emp) is translated to:
δ(D(γeid
The Set Difference Operator (−): Implementation of the difference operation R−T at the server is difficult since, without first decrypting the relations R and T, it is impossible to tell whether or not a given tuple of R also appears in S. However, the indices stored at the server can still be used to meaningfully reduce the amount of work done at the client. In the following we assume that relations R and T are set difference compatible and are defined over attributes A1, A2, . . . , An and B1, B2, . . . , Bn respectively. The following rule can be used to implement the set difference operator:
R−T=πR.A
R′=D(γLS(RS⊃Map
where L={A1S, A2S, . . . , AnS, B1S, B2S, . . . , BnS}.
Once again, the symbol S as a superscript of the left-outer join emphasizes (denoted ⊃) that the operator is implemented on the server side. We illustrate the above rule through an example. Suppose we want to compute emp-mgr, that is, we want to find all the employees who are not managers. The query is translated to the following query:
πemp.eid,emp.did(R′)−πmgr.mid,mgr.did(R′)
R′=D(γeid
The condition C′ is: Mapcond(emp.eid=mgr.mid)C1, where C1 is defined in Section 3. (See Attribute1=Attribute2.)
A few observations about the above implementation of the set-difference operator are noteworthy. First, the grouping of the results based on index attributes is not necessary—that is, the translation would be correct even without the grouping operator. The reason for including the grouping operator is that it can significantly reduce the computation on the client. For example, due to the grouping operator, all the tuples that have a NULL value for TS attributes will be grouped together. When the resulting tuples of the set difference operator arrive at the client, such tuples can be decrypted and the corresponding R tuple immediately returned as an answer. The reason is that there are no matching tuples of T that could cause the potential elimination of these tuples of R. Hence, the projection and the subsequent set difference implemented on the client side may only be restricted to those tuples for which the corresponding T value is not NULL.
Furthermore, in computing the projection to the attributes of R and S and the subsequent set difference between the two projections we only need to consider a single group formed by γLS operator at a time. That is, a T tuple from a different group will not eliminate an R tuple from another group. Thus, performing the grouping at the server side, while not necessary, could significantly reduce the computation at the client.
Second, even with the above optimization, the implementation of the set-difference operator using the outer-join on the server should be used with care. A naive strategy is to transmit the entire relations RS and TS to the client, which decrypts them and computes the set difference. This naive strategy might be cheaper than the previous strategy since the size of the outerjoin might be quadratic resulting in high transmission and decryption cost compared to the strategy of transmitting the two relations individually and computing the set difference at the client. Which strategy is used depends upon the content of the relations. Selecting the specific strategy depends upon integrating our framework into a cost-based query optimizer, which is beyond the scope of this paper.
The Union Operator (∪): There are essentially two different union operators based on the bag and the set semantics. The former does not eliminate duplicates, while the latter does. The implementation of the union operator based on bag semantics is straightforward:
R∪T=D(RS∪STS)
If we wish to compute the union under the set semantics, it can be computed as follows:
R∪T=δ(D(τLS(RS∪STS)))
where L=list of all attributes AiS where Ai is an attribute in R.
While the implementation of the union operator on the server side (that is, ∪S) is straightforward, there is one technical challenge that arises. Specifically, since tuples in RS∪STS could originate either from RS or TS, to be able to apply the correct decryption function at the client, as well as to correctly interpret the values in the index attributes of the result at the server, we will store an additional attribute in the result of the union that will determine the origin of the tuple (that is, whether it originates from RS or TS). Adding such an attribute is crucial for the correct implementation, but we will ignore it in the discussion to keep the algebra simple. The full version of the paper [5] illustrates the need for maintaining the additional attribute and the resulting modifications to the mapping functions and developed algebra.
The Projection Operator (π): Since each tuple in a relation R is encrypted together into a single string in the etuple attribute of relation RS at the server, a projection π is not implemented at the server. As a result, to compute πL(R), where L is a set of attributes, the strategy is to transmit the complete relation RS to the client, decrypt the relation at the client, and then compute the projection. That is,
πL(R)=πL(D(RS))
For instance, we have πeid(emp)=πeid(D(empS)).
5. Query Splitting
Given a query Q, our purpose in this section is to develop a strategy to split the computation of Q across the server and the client. The server will use the implementation of the relational operators discussed in the previous section to compute as much of the query as possible, relegating the remainder of the computation to the client. Our objective is to come up with the “best” query plan for Q that minimizes the execution cost. In our setting, the cost of a query consists of many components—the I/O and CPU cost of evaluating the query at the server, the network transmission cost, and the I/O and CPU cost at the client. A variety of possibilities exist. For example, consider the following query over the emp table that retrieves employees whose salary is greater that the average salary of employees in the department identified by did=1.
The corresponding query tree and some of the evaluation strategies are illustrated in
5.1 Heuristic Rules to Separate Queries
It should immediately be obvious that a rich set of possibilities exist in evaluating a query in our framework, and that the decision of the exact query plan should be cost based. This topic, however, is outside the scope of this paper. Our attempt is primarily to establish the feasibility of the proposed model, and cost-based optimization is relegated to future work. Instead, in this section, we will restrict ourselves to a simpler task—we will explore heuristic rules that allow for a given query tree to be split into two parts—the server part (referred to as QS) that executes at the server first, and the client part (referred to as QC) that executes at the client based on the results of the query evaluated at the server. Our objective will be to minimize the computation in QC. That is, we would attempt to rewrite the query tree, such that most of the effort of evaluating the query occurs at the server, and the client does least amount of work.
We illustrate our ideas using examples. As a first example, consider the following query that computes the names of the managers of those employees working on project “diskdrive” whose salary is more than 100K.
The first step is to convert the above query into a corresponding query tree, and to manipulate the query tree to generate a good plan (using the standard query rewrite laws of relational algebra [13]).
As it stands, the current query tree requires the entire relations projS, empS, and mgrS to be sent to the client that will decrypt the relations to evaluate the query. We next replace the selection operations by their implementation listed in the previous section resulting in the query tree shown in
using the standard rewrite rules involving selections in relational algebra [13]. The new query tree is shown in
is executed at the server.
above the join operator
Then, we replace the join operator based on the implementation discussed in the previous section, and get the final query tree, as shown
Notice that in the tree of
There are situations when the selection operator cannot be pulled up the query tree as it is illustrated in the following example, which uses a set-difference operator. Consider a query that retrieves the set of employees who do not work for the manager named “Bob.” The corresponding SQL query is shown below:
Using the strategy discussed above, we can easily convert the query into the query tree shown in
6. Implementing Aggregation Over Encrypted Relations
This section explores extensions to the general techniques described above in order to support aggregation in a relational database on encrypted data in the presence of logical and textual predicates. Note that 100% of queries in the TPC-H, decision support benchmark, 20% in the TPC-C, OLTP benchmark, and 13.5% in the TPC-W, e-commerce benchmark, require aggregation. Efficient aggregation support is important.
SQL is a large complex language [20]. In order to explain our methods and techniques in limited space, we use a simple but general query form. The specific form of aggregation queries considered further (techniques discussed herein have wider applicability) in the paper is:
Here, <aggregation function> refers to any SQL aggregation function (SUM,COUNT,AVG,MIN,MAX) with arithmetic expression as the parameter. <predicates> may include logical comparisons and text matching as supported by SQL's LIKE (NOT LIKE) predicate, between an alphanumeric attribute and text pattern with wildcards.
Our techniques exploit a specialized encryption method, privacy homomorphism (PH for short), that allows basic arithmetic (+, −, ×) over encrypted data. The primary contributions of this paper include: (1) The first application of PH to aggregation queries in relational databases including extensions to make it applicable. (2) Application of a signature based filtering technique to solve the problem of evaluating the SQL LIKE predicate on encrypted textual columns, (3) Formal techniques to transform SQL aggregation queries to execute over encrypted tables including demonstration of cost based optimization opportunities, and (4) performance studies based on a real queries against a real database to validate the ideas.
6.1 Privacy Homomorphism (PH)
Definition of PH: Assume A is the domain of unencrypted values, Ek an encryption function using key k and Dk the corresponding decryption function, i.e., ∀aεA, Dk(Ek(a))=a. Let {tilde over (α)}={α1, α2, . . . , αn} and {tilde over (β)}={β1, β2, . . . , βn} be two (related) function families. The functions in {tilde over (α)} are defined on the domain A and the functions on {tilde over (β)} are defined on the domain of encrypted values of A. (Ek,Dk,{tilde over (α)},{tilde over (β)}) is defined as a privacy homomorphism if Dk(βi(Ek(a1), Ek(a2), . . . , Ek(an))=ai(a1, a2, . . . , an):1≦i≦n. Informally, (Ek,Dk,{tilde over (α)},{tilde over (β)}) is a privacy homomorphism on domain A, if the result of the application of function αi on values may be obtained by decrypting the result of βi applied to the encrypted form of the same values.
Given the above general definition of PH, we next describe a specific homomorphism proposed in [10] that we will use in the remainder of the paper. We illustrate how the PH can be used to compute basic arithmetic operators through an example.
We illustrate how PH works through the following example.
Example: Let p=5, q=7. Hence, n=p·q=35, k=(5,7). Assume that the client wants to add a1 and a2, where a1=5, a2=6. E(a1)=(0,5), E(a2)=(1,6) (previously computed) are stored on the server. The server is instructed to compute E(a1)+E(a2) componentwise (i.e., without decrypting the data). The computation E(a1)+E(a2)=(0+1,5+6)=(1,11). The result, (1,11) is returned to the client. The client decrypts (1,11) using the function:
(d1qq−1+d2pp−1)(mod n)=(1·7·3+11·5·3)35=186(mod 35)
which evaluates to 11, the sum of 5 and 6, wherein n is selected in such a way that results always fall in [0,n) (for this example [0,35)). Assume the client wants to multiply 5 and 6. The server would be instructed to perform componentwise multiplication giving us (0,30). (0,30) is sent back to the client, and decrypted as 3035=30, which is the correct answer. The scheme extends to subtraction.
The proof of correctness of decryption uses the Chinese Remainder Theorem, and is found in [38]. We note that for encryption PH relies on the difficulty in factorizing n into its component prime factors p and q. This, in turn, relies on p and q to be very large prime numbers. Thus, for the PH based scheme to be used, the server will need to deal with large number arithmetic. It is, therefore, vital that the proposed strategy be used in conjunction with an efficient large integer arithmetic implementation. There are available efficient software solutions, such as [36,31], which are widely used in many applications. In addition, hardware solutions have also been studied and implemented [29] by using recent technologies such as PAM [40]. Those solutions improve software solutions by order of magnitude [37]. These results are even faster than reported results for a Cray II or a Cyber 170/750 [23].
While hardware techniques overcome the CPU overhead of large number arithmetic, since data is stored on disks, PH increases the storage requirement which would lead to increased I/O cost in the database. For example, a 4 byte integer of the original attribute might be represented as a large 64 byte representation. We have explored two strategies to address this problem. First, we can fragment the encrypted relation into multiple tables such that aggregation attributes are stored separately. This way, the additional overhead is not incurred by queries that do not need to compute aggregations. Additionally, we have developed a technique using which a number of original values of numerical attributes can be packed together to form a large integer value which is then encoded using PH together. For example, instead of storing 64 bytes for each aggregate attribute of the relation, we can utilize the space available to us (i.e., 64 bytes) to pack a number of 4-byte integer values together. The details of the value packing strategy are complex and we do not discuss those further due to space limitations. Instead, we refer the interested reader to [5]. We note that our experiments will show that with these techniques in place, the I/O overhead of using PH is not very significant.
6.2 Extensions to PH
The basic PH scheme above works for modular addition, subtraction, and multiplication of integers only, and needs to be extended in several directions for it to be useful in SQL query processing. SQL arithmetic requires arbitrary expression evaluation using non-modular addition, subtraction, multiplication, and division functions on signed integers and floating point data types. We discuss some of these extensions below (details can be found in [5]).
Division may be supported by leaving the result in fractional form—i.e., by computing the numerator and the denominator of the division separately. For example, if we had to compute
we could compute the numerator and denominator of the result as a1c2+a2c1 and c1c2, respectively. Both only involve addition and multiplication, which are supported by the PH. They could be computed separately and returned to the client which decrypts them and performs the final computation.
Floating point numbers can be handled by exploiting the fact that they are finite precision and can therefore be represented as a fraction.
Negative numbers can be dealt by offsetting the range of numbers. To see the need for this, recall that arithmetic is defined on modulo n in PH. For example, the numbers 33 and −2 are indistinguishable when we represent them in modulo 35. That is, 33 (mod 35)≡−2 (mod 35). Let vmin be the smallest negative and vmax the largest positive number representable on a machine. We map the range of numbers [vmin, vmax] to a new range [0,(vmax−vmin)], n is chosen to be greater than vmax−vmin. A number x is mapped to a shifted value x′ in the new range as x′=x−vmin. After decryption, the client corrects the answer and maps, in a straightforward manner, back to values in the original domain.
Preventing Test for Equality: Picking n such that n>vmax−vmin (as we did above) enables the server to test for equality. Say x and y are two numbers encrypted as (xp, xq) and (yp,yq), respectively. Let z=x*y, which implies in the encrypted domain, (zp,zq)=(xp,xq)*(yp,yq). The server could start adding (xp,xq) to itself every time checking the equality between the sum and (zp,zq). When the equality is satisfied, the server learns the unencrypted value of y. Thus,
We plug this exposure by adding random noise to the encrypted value. We encrypt an original value x as follows; E(x)=(x(mod p)+R(x)·p,x (mod q)+R(x)·q), where R(x) is a pseudorandom number generator with seed x. R(x) value is generated during every insertion/update by the client. This prevents equality testing for the server and the server cannot remove the noise without knowing p and q. The noise is automatically removed at the client upon decryption. In the presence of noise, the following decryption function should be used in place of equation (1) above:
Dk(d1,d2)=(d1 mod p)qq−1+(d2 mod q)pp−1(mod n) (2)
This equation is true because noise had been added in multiples of p for the first and in multiples of q in the second term. The modulo of each p and q term removes the added noise.
Another benefit of introducing noise is that p and q components are no longer stored in modulo p and q, respectively. It makes it additionally difficult for the administrator to guess their values (and hence to break the encryption scheme).
6.3 Aggregation Queries without Selection
Having appropriately extended PH, we now describe mechanisms to compute simple aggregation queries that do not contain any selection conditions (i.e., WHERE clause) over the encrypted domain. We do so in the remainder of this section. Dealing with more complex aggregation queries (with selection) is the topic of Sections 6.5 and 6.6.
Consider an aggregation query that computes the total compensation of employees: that is SUM(salary+commission) from the employee relation. Let employeeS be the encrypted server side representation of an employee relation. The relation is encrypted at the row level by treating a record as a bit string that is encrypted as a unit. employeeS, besides storing the resulting ciphertext as a special field, also contains fields salaryph and salaryqh that store the values salary (mod p), and salary (mod q); i.e., together the two fields encode EPH(salary), where EPH is a PH used to encrypt salary. Similarly, commissionph and commissionqh fields represent commission using the PH strategy.
The original query can be evaluated by computing the aggregation component-wise at the server using the following query:
The client can decrypt the result by computing:
s1 mod p*q*q−1+s2 mod q*p*p−1(mod n)
The example captures the intuition underlying our scheme. Two important issues still need to be resolved. First, the aggregation function might be more complex (e.g., ). Arbitrary arithmetic expressions can easily be handled in PH. For the above example, the computation will map to the server side computation as follows:
SUM(yearly_salaryph+bonus_levelph*1000p),
SUM(yearly_salaryqh+bonus_levelqh*1000q),
where 1000p and 1000q represent p and q components of value 1000, respectively. Secondly, we have so far focussed on the SUM function in the discussion. We explain how other aggregations can be handled below.
6.4 Handling Other Aggregation Functions
We note that COUNT, by itself, does not involve arithmetic and hence does not pose any additional difficulty due to PH. AVG function can be implemented as a combination of SUM and COUNT (namely, SUM/COUNT).
The MIN and MAX functions cannot be directly supported using PH. The PH, which is used for aggregation attributes, does not preserve the order of the original data. It is already established in [10, 28, 29] that if a PH preserves order then it is insecure. Hence, we have devised different mechanisms to compute minimum and maximum values as follows.
We note that, besides supporting logical comparisons, the domain partitioning strategy can also be used to support the MIN and MAX functions. Since the order of the partitions is known to the client as metadata information, the client can exactly identify and request the partition(s) that may contain the minimum and maximum values. After receiving the etuples in the requisite partitions, the client can decrypt and find the exact values of MIN and MAX function by only evaluating within the partitions.
6.5 Selecting Tuples Over Encrypted Data
This section describes mechanisms to select tuples that satisfy conditions specified in the WHERE clause of the query over the encrypted data representation. Specifically, we focus on conditions involving (1) logical comparisons (<, >, =, ≦, ≧, ≠), and (2) pattern matching over text attributes, e.g., Mary*.
Testing such conditions directly on encrypted data is difficult—cryptography literature lacks any general solutions. For example, there do not exist any provably secure solutions to test if a given pattern (e.g., ‘% Mary % M %’) appears in encrypted textual data [38]. Likewise, it is difficult to test conditions such as salary >60K directly over the encrypted domain.
To alleviate the problem, we store additional information in the form of an index with the data that enables testing if a tuple satisfies the query condition. The approach could result in false positives—that is, it may identify a superset of the real answer set that will need to be filtered out at the client upon decryption. We discuss these next.
6.5.1 Logical Comparisons
To support logical comparisons (<, >, =, ≦, ≧, ≠) over encrypted data, we differentiate between equality and inequality operators. Consider an attribute Ai on which equality test needs to be performed (e.g., as part of a equi-join or selection operation). If we encrypt the attribute value using a deterministic encryption algorithm, such as AES [1], Blowfish [12], DES [3], etc., and store the encrypted field value at the server, equality can be directly tested since domain values vi, vj,vi=vjEk(vi)=Ek(vj), where Ek is a deterministic encryption algorithm with key k.
For inequality comparisons (e.g., <,>) we utilize the strategy proposed in [32]. Consider a relation employee(eid,ename salary,city,did) an instance of which is shown in Table 5 below.
Suppose we wish to retrieve eid of employees who make more than 60K. To evaluate conditions such as salary >$60K, a coarse index at the server (that can be used to filter out false positives) is stored. Such a coarse index is derived by first partitioning the domain of salary into a set of partitions (or buckets) over the domain of salary (assumed to be between [0,100K] below). For example:
partition(employee.salary)={[0K,25K],(25K,50K],(50K,75K],(75K,100K]}
Associated with each partition is its identity determined by an identification function ident that could be derived using, for example, a 1-way hashing technique. A particular assignment of identifiers to 4 salary partitions is shown in Table 6 below.
For instance, identemployee.salary([0,25K])=59. A value in the domain can be mapped using the partitioning to its corresponding partition. For example, the salary of Tom in the above table maps to partition 81; that is, Mapemployee.eid(70K)=81. This mapping is used as a coarse index at the server in order to support comparison operators over the encrypted data. For example, to test if a tuple satisfies the condition salary >60K, we can test the condition salaryid=81 OR salaryid=7 at the server. If the tuple satisfies the condition, its encrypted representation is returned to the client that can decrypt the results to filter out false positives. We also note that, the strategy allows handling of predicates, which include arithmetic expressions, in WHERE clause [32].
A fundamental question is how should the domain be partitioned and into how many partitions. The choices may have both performance and privacy implications. We point the interested reader to [32] that considers and experiments various partitioning strategies (e.g., equi-width, equi-depth) for this purpose.
6.6 Pattern Matching Conditions
For a given attribute of string type (e.g., ename), we propose that the client associates a set of n-grams denoted by N, where an n-gram is a consecutive sequence of characters of arbitrary length. Based on the set of n-grams, each attribute value (string) is represented at the server by a signature that contains a bit per n-gram in N (using an inverted list is an alternative). For example, given N={go,ry,M}, ename attribute value “Mary” of the second record in Table 1 will be represented using a signature “011” since the n-gram ry and M are found in “Mary” but go is not. Thus, in the encrypted representation of the relation, for each string type on which LIKE queries need to be supported, we add a new attribute that stores the signature for the string.
The client maintains the list of selected n-grams. Given a query, the client determines the signature values for the query string mentioned in the LIKE predicate. For example, for N={go,ry,M}, the query string “% Mary % M %” will be converted into the corresponding signature “011” OR “111” (boolean minimization techniques are applicable) since ry and M are contained in “% Mary % M %” and go is not. Using the query signature, a (superset) of tuples that match the query pattern can be identified at the server which can be filtered at the client after decryption.
Similar to domain partitioning strategies, the choice of the set of s could significantly impact the text query performance and security guarantees. From a performance perspective, one desires a set of s that minimize false positives for pattern queries. Optimal selection has been recently studied for document indexing [24]. However, unlike their work, our problem setting is different and imposes different design concerns. First, since clients may have limited storage or processing capability, we require that the number and size of n-grams be limited. Further, n-grams creation should not involve expensive passes over the large databases stored at the server. This would require the client to transfer the data from the server, decrypt and process it to compute the n-grams. Finally, the choice of n-grams used to index the text field should not compromise data privacy.
We followed a very simple gram selection policy that randomly selected n-grams out of the set of all feasible after appropriately biasing the selection process to choose, for any size k, grams with equal probability by factoring their different cardinalities. That is, our selection process ensured that the probabilities of selecting n-grams of length 1,2, . . . , m:1≦m≦k are equal.
6.6 Query Processing Over Encrypted Data
Having developed basic methods to compute aggregations, compare values, and support pattern queries, we now turn our attention to techniques to evaluate SQL queries over encrypted data. We begin by first formally specifying how relational data is stored at the server. We will then discuss techniques to map a query into the server side representation.
6.6.1 Storage Model
Let R be a relation with the set of attributes {tilde over (R)}={r1, . . . , rn}. R is represented at the server as an encrypted relation RS that contains an attribute etuple=Et(r1, r2, . . . , rn), where Et is the function used to encrypt a row of the relation R. RS also (optionally) stores other attributes based on the following classification of the attributes of R:
Given the above attribute classification, the schema for the relation RS is as follows:
RS(etuple,P1id, . . . , Pm′id,F1f, . . . , Fk′f,W1g, . . . , Wt′g,A1h, . . . , Aj′h)
Table 7 shows a possible instance of the server side representation of the employee relation given in Table 5.
In the mapping, we assumed that partitioning attributes are {eid,salary,city,did}, field level encrypted attributes are {city,did}, string attributes are {ename}, and aggregation attributes are {salary}.
Note that for a relation, the categories may overlap. For example, if an attribute is expected to be used for both selection and aggregation, we might represent it as both an aggregation and partitioning attribute. Similarly, an attribute may be represented both as a partitioning and a field-level encrypted attribute—the latter will facilitate efficient evaluation of equi-join or equality selection queries, whereas, the former will support other general queries. This allows flexibility to the model and enables customization of the system for specific performance, security, and storage requirements.
6.7 Aggregation Approach Query Overview
Given a query Q, our problem is to decompose the query to an appropriate query QS on the encrypted relations RS such that results of QS can be filtered at the client in order to compute the results of Q. Ideally, we would like QS to perform bulk of the work of processing Q. The effectiveness of the decomposition depends upon the specifics of the conditions involved in Q and on the server side representation RS of the relations involved. Consider, for example, a query to retrieve sum of salaries of employee in did=40. If did is a field-level encrypted field (as is the case in our example), the server can exactly identify records that satisfy the condition by utilizing the equality between the client-supplied values and the encrypted values stored on the server. In such a case, aggregation can be fully performed on the salary attribute of the selected tuples exploiting the PH representation. If, on the other hand, the condition was more complex, (e.g., did >35 AND did <40), such a query will be mapped to the server side by mapping the did to the corresponding partitions associated with the did field that cover the range of values from 35 to 40. Since the tuples satisfying the server side query may be a superset of actual answer, aggregation cannot be completely performed at the server. Our strategy is to separate the qualified records into those that certainly satisfy the query conditions, and those that may satisfy it—the former can be aggregated at the server, while the latter will need to be transmitted to the client, which on decrypting, can filter out those that do not, and aggregate the rest. The strategy suggests a natural partitioning of the server side query QS into two queries QcS and QmS as follows:
To finalize the computation, the client combines results from these queries to reach the actual answers. We next discuss how a client side query Q is translated into the two server side representations QcS and QmS.
6.7 Query Translation
The principal issue in decomposing the query Q into its server side representations QcS and QmS is to map the conditions specified in Q to corresponding conditions on the server side representation. We first consider how an individual condition Ck of Q is mapped. Our mapping function Mapcond(Ck) consists of two components: Mapcondc(Ck) and Mapcondm(Ck). Mapcondc(Ck) maps Ck to a server side condition such that every tuple satisfying Mapcondc(Ck) certainly satisfies Ck, while Mapcondm(Ck) maps Ck into a condition that qualifies tuples that maybe satisfies Ck. Together, the two conditions identify (a superset of) tuples that satisfy the original condition Ck. Naturally, Mapcond(Ck)=Mapcondc(Ck)Mapcondm(Ck). We will use the following notation to describe how conditions in the original query are mapped to their server side representation.
Let R be a relation, R.Ai be a partitioning attribute of R, let {p1, p2, . . . , pn} be the set of partitions associated with R.Ai, and v be a value in the domain of R.Ai. We define the following mapping functions on the partitions associated with Ai:
MapR.A
MapR.A
where pk.low and pk.high are the low and high ranges associated with the partition.
6.7.1 Mapping Conditions
Attribute=Value: We can evaluate the condition by testing equality between the field level encrypted values of the attribute Ai and the value v given in the condition, i.e., Aif=Ek(v). The result is exactly the set of records that satisfy the condition since, for deterministic encryption, Aif=Ek(Ai) and Ai=vEk(Ai)=Ek(v) Thus,
Mapcond(Ai=v)≡Mapcondc(Ai=v)≡Aif=E(v)
For instance, consider the employee table, and mapping of the following condition:
Mapcond(salary=84K)≡Mapcondc(salary=84K)≡employeeS.salaryf=E(84K)
Attribute <Value: We utilize partitioning attributes to map the condition. Since the query condition may fully contain some of the partitions and partially overlap with the others, Mapcond function will have both components Mapcondc and Mapcondm.
where PC
Consider the mapping of the following condition as an example:
Mapcond(salary<60K)≡Mapcondc(salary<60K)Mapcondm(salary<60K)
Mapcondc(salary<60K)≡salaryid=59salaryid=49
Mapcondm(Ai<v)≡salaryid=81
since salary <60K condition fully overlaps with [0K, 25K] identified by 59 and (25K, 50K] identified by 49, and it partial overlaps with [50K, 75K] identified by 81.
Attribute1=Attribute2: For this case, we again exploit the field level encrypted attributes of encrypted relation. We can test the equality of two attribute values directly over their encrypted values, as Ai=AjEk(Ai)=Ek(Ai) due to deterministic encryption. (We make an assumption that the same key is used to encrypt the attributes Ai and Aj). As a result, Mapcond includes only Mapcondc component for this type of condition. Thus, this type of conditions may be evaluated completely on the server.
Mapcond(Ai=Aj)≡Mapcondc(Ai=Aj)≡Aif=Ajf
For example:
Attribute1<Attribute2: To evaluate the condition, we need to test the order of the values of two attributes mentioned in the condition. Since the encryption algorithms, which may be used for field level encrypted attributes and for aggregation attributes do not preserve the order of the original data, they may not be used for the test. Therefore, we use partitioning attributes to evaluate the condition.
The condition is mapped by considering all pairs of partitions of Ai and Aj that could satisfy the condition. The pairs that have overlap (either fully or partially) are subject to Mapcondm function. The other pairs, which do not overlap while satisfying the condition, are subject to Mapcondc function. Formally, the mapping is defined as follows:
where φ is pmεpartition(Ai), pnεpartition(Aj), pn.low>pm.high and γ is pkεpartition(Ai), plεpartition(Aj), pl.low<pk.high
Consider the partitioning schema for two attributes in Table 8 above and the following condition to be mapped:
Mapcond(employee.did<manager.did)≡Mapcondc(employee.did<manager.did)Mapcondm(employee.did<manager.did)
where:
Mapcondc(employee.did<manager.did)≡(employeeS.didid=2managerS.didid=34)(employeeS.didid=2managerS.didid=56)(employeeS.didid=4managerS.didid=56)
and:
Mapcondm(employee.did<manager.did)≡(employeeS.didid=2managerS.didid=21)(employeeS.didid=4managerS.didid=56)(employeeS.didid=4managerS.didid=34)(employeeS.didid=3managerS.didid=56)
Attribute LIKE ‘% query_string %’: In this case, we make use of string signatures to evaluate the condition. First, we determine the signature values for the query string mentioned in the LIKE predicate and construct the query bit vector. This bit vector replaces the query string in the mapped condition. Wildcards are handled in a straightforward manner [24]. Formally,
Mapcond(AiLIKE q)≡Mapcondm(Ai LIKE q)≡Aig=G(q)
where q is query string and G(·) is signature generator function, which generates a bit vector {right arrow over (b)}={b1, . . . , bn}, where biε{0,1}:1≦i≦|N| and N={g1, . . . , gn} is given set of pre-selected n-grams. Thus, G(q)={right arrow over (b)}={b1, . . . , bn}, where bi=1, if gi is a substring of q; bi=0 otherwise.
For brevity we skip the discussion on how other atomic conditions involving operations >, ≦, ≧ are mapped. We note that the mapping for operator > is symmetric to that of <. Similarly, operator ≦ follows the same mapping as < and operator ≧ that of >. Mapping composite conditions, i.e., conjunction and disjunction of atomic conditions, is trivial [5].
6.7.2 Query Decomposition
Once all conditions are translated according the mappings given above, we need to identify the parts of the conditions that will be evaluated by QcS and the remaining part that will be evaluated by QmS. This also will represent separation of those two queries. To separate the conditions, we first map each condition by using mapping functions given above. Then, we convert the resulting conditions into disjunctive normal form (DNF) and split the disjuncts into two classes:
The above classification suggests a natural splitting of the server side query into two parts: QcS and QmS·QcS is formed with the first class of the disjuncts, which only contain functions and QmS is formed with the second class of disjuncts, which contain functions. Algorithmic steps of this procedure are given below:
Input: Composite condition W of original query Q
1. For each atomic condition Ci in W
2. Build mapped composite condition W′ with Ci's
3. Convert W′ into DNF
4. Define Dc as set of disjuncts having only Mapcondc
5. Define Dm as set of disjuncts having only Mapcondm
6. Form query QcS with Dc in WHERE clause
7. Form query QmS with Dm in WHERE clause
For QcS, the GROUP BY attributes in the SELECT clause are replaced by their field-level encrypted attributes and the aggregation is replaced with the corresponding aggregation over the PH representation of the attribute. The result of QcS will be the encrypted representation of the group value along with the PH encrypted value of the corresponding aggregation. The client can decrypt the group values and the encrypted aggregations. For QmS, the SELECT clause is replaced by the selection etuples that will be sent to the client. The client will need to decrypt the etuples to determine those that satisfy the conditions associated with query Q. Subsequently, it will perform the corresponding GROUP BY and aggregations.
The client can determine the final result of the aggregation query by merging the results of the individual computations of the two queries. The mechanism to merge the results of the two queries depends upon the specific aggregation function associated with the query. For the SUM and COUNT queries the result can be obtained by adding the result of the two queries. For MIN and MAX, the result can be obtained by computing the minimum and the maximum of the results of the two queries respectively. For AVG, each query needs to return the SUM and the COUNT separately which can then be used to determine the overall aggregate value.
In this section, we explain our strategy by walking through the steps of the query translation discussed above using an example query over the employee and manager tables. Sample population of employee table is given in Table 1 and partitioning scheme of salary attribute of employee is given in Table 2. Consider the following query, which has composite condition W: city=‘Maple’ salary <65K emp.did=mgr.did consists of three atomic conditions, namely, C1: city=‘Maple’, C2: salary <65K, C3: emp.did=mgr.did;
SELECT SUM(salary)
FROM employee, manager
WHERE city=‘Maple’ AND salary <65K AND emp.did=mgr.did
Let us now generate the server side representation of the original query by following the algorithm steps provided above.
1. We first map each atomic condition by identifying Mapcondc and Mapcondm parts. Hence, the conditions are mapped as follows:
C1: Mapcond(city=‘Maple’)≡Mapcondc(city=‘Maple’)≡cityf=E(‘Maple’)
C2: Mapcond(salary<65K)≡Mapcondc(salary<65K)Mapcondm(salary<65K)
Mapcondc(salary<65K)≡salaryid=49salaryid=59
Mapcondm(salary<65K)≡salaryid=81
C3: Mapcond(emp.did=mgr.did)≡Mapcondc(emp.did=mgr.did)≡emp.didf=mgr.didf
2. Thus, mapped composite condition W′ is formed as:
W′: cityf=E(‘maple’)(salaryid=49salaryid=59salaryid=81)emp.didf=mgr.didf
3. Now we can convert W1 into DNF:
We put curly braces to show the class, whether they are Mapcondc or Mapcondm, of the mapped conditions and label them with the disjunct labels, D1, D2, D3. This information is used to in the next step, where we define Dc and Dm sets.
4. From the previous step, the set Dc, only having Mapcondc, is defined as {D1, D2}.
5. The set Dm, having Mapcondm, is defined as {D3}.
Now, we can form the server side representation of the original query by forming two queries: QcS and QmS as follows:
6. QcS:
7. QmS:
QcS evaluates and returns the aggregation, SUM(salary), on encrypted relation by exploiting the PH. QmS selects tuples which may satisfy the original query condition (but the server cannot determine if they do). In our example, these correspond to the first two tuples of the employees relation (see Table 7). The query returns the corresponding etuples to the client. Upon decryption, the client can figure that, the first tuple (which has salary=70K) does not satisfy the query and should be eliminated. The second tuple, however, which has salary=60K, satisfies the query condition and should be taken into account. The client finalizes the computation by combining the answer returned by the first query, QcS, and those condition-satisfying tuples returned by the second query, QmS.
6.9 Reducing the Maybe Set
In our framework, so far, a server side aggregation query QS is split in two: QcS and QmS whose results form the certain and maybe answer sets, respectively. While results of QcS can be aggregated at the server, results of QmS are shipped to the client, where they are decrypted, and combined with the aggregation over results of QcS. In the DAS model, our primary concern is to minimize the client-side post processing overhead. The dominant client-side costs include the cost of decrypting and filtering results both of which are proportional to number of records returned by the server for final processing (i.e., the size of the maybe set). Therefore, large increases in the size of maybe set (e.g., presence of pattern matching predicates) would cause increasing overhead at the client. In this section, we explore further opportunities to reduce the client side cost by minimizing the records returned by the server to the client. This is achieved by selectively choosing a subset of selection operations in the query to remove uncertainty in their maybe sets in order to minimize the overall cost of the query. We illustrate our ideas through an example. Let us consider the following query:
Let us assume that after the rewrite, based on the metadata stored at the client, QS is given as follows:
Further, let us assume that partitions {3,4} are fully overlapped and partition {5} is partially overlapped with T1. salary <90K condition. Similarly, partitions {17,18} are fully overlapped and partition {19} is partially overlapped with T2.date>‘1-1-2002’ condition. As the part of metadata the client maintains the number of records in each of the buckets. From that information, assume the number of records in each bucket is given as follows; for employee.salary attribute: |3|=100, |4|=100, and |5|=10, and for sales.date attribute: |17|=1000, |18|=1000, and |19|=1000. Let employee.eid be the primary key of employee table and the number of distinct eid values in the buckets {17,18,19} of e_sales table be 100.
Based on this scenario, a possible query execution tree is shown in
6.10 Use of Filtering Operator (ω)
b) shows an alternative strategy to evaluate the query in which, after the evaluation of the first selection, σs
6.11 Optimization Algorithm
The example above illustrates that the client-cost (i.e., number of maybe records) depends upon whether or not we filter the results of intermediate operations to remove the uncertainty, thereby converting a subset of maybe records into certain records. We can use a cost-based strategy to decide which subset of selection operations should be filtered using the ω operator in order to minimize the expected client-cost. This involves: (1) enumerating the possible subsets of the set of selection predicates that could be filtered using the ω operator, and (2) analyzing the cost for each possibility to choose the best strategy (plan).
We list the pseudocode of such an optimizer below:
In the above pseudocode, W refers to the set of atomic conditions Ci of the query.
Enumerating the set of possible plans (by listing subsets of conditions that could be filtered) is straightforward. The only challenge is in determining, given a plan P, its cost planCost(P)−total number of records sent to client for processing at any stage of query execution. This cost consists of two components: (1) number of tuples that are transmitted by various ω operators in the plan to the client (indicated as f in the algorithm); and (2) the size of the resulting maybe set that will finally be transmitted to the client for postprocessing (indicated as ec in the algorithm). The cost of ω operators can be determined by exploiting the metadata (maintained at the client) about cardinality of partitions being filtered by ω. The size of the final maybe set for a strategy can be estimated using standard selectivity estimation techniques for relational operators given the metadata (e.g., size) of input relations maintained at the client.
The above optimization can significantly improve performance specially for complex queries where uncertainty about a few records, lower in the corresponding query tree, could magnify into a very large maybe set due to a join/cartesian product. By filtering such records early, significant savings can be accrued. Note that our strategy does not just reduce client-cost—its important side effect is reduction in network cost. Moreover, since additional records get filtered early, it could also result in some server side savings as well. For example, query plans given in
While the cost-based approach may improve performance, it comes at the price of software complexity due to additional collaboration between the client and the server in computing the query. Note that in our basic strategy, a client query is mapped into two server side queries QmS and QcS. If we are to use the optimized strategy, the mapping of the query processing strategy induced by the chosen plan may result in many serverside queries. For example, the strategy suggested in
7. Logic Of Preferred Embodiment
Block 900 represents the step of transforming a computation formulated to be performed on unencrypted data so that at least a portion of the computation can be applied to the encrypted data.
Block 902 represents the step of applying the transformed computation to the encrypted data in order to obtain intermediate encrypted results.
Block 904 represents the step of decrypting the intermediate encrypted results.
Block 906 represents the step of applying at least a remaining portion of the computation to the decrypted results in order to obtain actual results for the computation.
Preferably, the transforming step 900, decrypting step 904 and applying step 906 are performed by a client computer and the applying step 902 is performed by a server computer. Consequently, the server computer stores the encrypted data, the client computer sends the transformed computation to the server computer, and the server computer sends the intermediate encrypted results to the client computer.
In one embodiment, additional information is stored with the encrypted data, wherein the additional information comprises one or more partition ids associated with at least one attribute of the encrypted data. The partition ids are created by partitioning a value domain of the attribute of the encrypted data and labeling partitions resulting therefrom. Preferably, the partitions cover a whole of the value domain, and the partitions do not overlap.
As a result, Block 900 further comprises the step of partitioning at least one operation of the computation for execution across the client computer and the server computer, as set forth below:
In another embodiment, additional information is stored with the encrypted data, wherein the additional information comprises results from one or more modulo divisions of the attribute by components of an encryption key.
As a result, Block 900 further comprises the step of partitioning at least one operation of the computation for execution across the client computer and the server computer, as set forth below:
With regard to the applying step of Block 902, this may also comprise step of applying the transformed computation to the encrypted data using one or more privacy homomorphisms that support arithmetic operations on the encrypted data, wherein the arithmetic operations are defined in modular arithmetic and a modulo divisor n is selected such that n=p*q, where an encryption key for the encrypted data comprises k=(p,q), and results from the modular arithmetic fall in a range defined by [0,n).
The arithmetic operations may include:
Although
The following references are incorporated by reference herein:
This concludes the description of the preferred embodiment of the invention. The following describes some alternative embodiments for accomplishing the present invention. For example, any type of computer, such as a mainframe, minicomputer, or personal computer, could be used with the present invention. In addition, any software program performing database queries with the need for encryption could benefit from the present invention.
In summary, the present invention discloses a client-server relational database system, wherein data from the client computer is encrypted and hosted by the server computer, the encrypted data is operated upon by the server computer, using one or more operators selected from a group of operators comprising: (a) inequality logic operators, (b) aggregation operators, and (c) wildcard matching operators, to produce an intermediate results set, the intermediate results set is sent from the server computer to the client computer, and the intermediate results set is decrypted and filtered by the client computer to produce actual results. The group of operators is limited because the encrypted results set, when decrypted, includes inaccuracies therein. The client computer applies a set of correction procedures to the decrypted results set to remove the inaccuracies therein.
The foregoing description of the preferred embodiment of the invention has been presented for the purposes of illustration and description. It is not intended to be exhaustive or to limit the invention to the precise form disclosed. Many modifications and variations are possible in light of the above teaching.
This application is continuation under 35 U.S.C. §120 of U.S. patent application Ser. No. 10/449,421, filed on May 30, 2003, by Vahit H. Hacigumus et al., entitled “QUERYING ENCRYPTED DATA IN A RELATIONAL DATABASE SYSTEM,” which application is incorporated by reference herein.
Number | Name | Date | Kind |
---|---|---|---|
5442699 | Arnold et al. | Aug 1995 | A |
5713018 | Chan | Jan 1998 | A |
5822751 | Gray et al. | Oct 1998 | A |
5963642 | Goldstein | Oct 1999 | A |
6226629 | Cossock | May 2001 | B1 |
6275824 | O'Flaherty et al. | Aug 2001 | B1 |
6275939 | Garrison | Aug 2001 | B1 |
6446092 | Sutter | Sep 2002 | B1 |
6785810 | Lirov et al. | Aug 2004 | B1 |
6792425 | Yagawa et al. | Sep 2004 | B2 |
6957341 | Rice et al. | Oct 2005 | B2 |
7228416 | Nishizawa et al. | Jun 2007 | B2 |
7266699 | Newman et al. | Sep 2007 | B2 |
7500111 | Hacigumus et al. | Mar 2009 | B2 |
20010019614 | Madoukh | Sep 2001 | A1 |
20020038421 | Hamada | Mar 2002 | A1 |
20020129260 | Benfield et al. | Sep 2002 | A1 |
20020174355 | Rajasekaran et al. | Nov 2002 | A1 |
20030055824 | Califano | Mar 2003 | A1 |
20030061205 | Cleghorn et al. | Mar 2003 | A1 |
20030123671 | He et al. | Jul 2003 | A1 |
20040181679 | Dettinger et al. | Sep 2004 | A1 |
20050044366 | Pucheral et al. | Feb 2005 | A1 |
Number | Date | Country |
---|---|---|
0855656 | Jul 1998 | EP |
WO 03081464 | Oct 2003 | WO |
Number | Date | Country | |
---|---|---|---|
20090077378 A1 | Mar 2009 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10449421 | May 2003 | US |
Child | 12272460 | US |