#PUCMM331. SQL Queries
SQL Queries
Structured Query Language (SQL) is a special-purpose programming language designed for manipulating relational data. Its most known feature is perhaps the Query, that is, a mechanism by which data can be retrieved based on custom criteria.
The general syntax to construct a SQL Query with filtering criteria is as follows:
SELECT [list of fields] FROM [table] WHERE [criteria]
Let us review an example. Consider we have the following table of competitive programmers:
Nickname | Country | CF_Rating | TC_Rating |
tourist | BY | 3205 | 3693 |
Petr | RU | 2676 | 3738 |
Egor | RU | 2732 | 3463 |
cjtoribio | DO | 2019 | 1381 |
niquefa_diego | CO | 2059 | 1896 |
Un_Exisstin3 | PE | 2400 | 1499 |
If we wanted to retrieve all competitive programmers who have a CodeForces rating less than 2200 or a TopCoder rating of at most 1500, we could construct the following query:
SELECT Nickname FROM Comp_Programmers WHERE CF_Rating < 2200 OR TC_Rating <= 1500
In this example, the query would return nicknames cjtoribio, niquefa_diego and Un_Exisstin3.
We will consider a simplified SQL statement. Assume there is only one table with the same structure as the one provided in the above example. Your program will receive a single criteria with exactly two conditions on the columns CF_Rating and TC_Rating, assembled with either the AND or the OR operator. With this criteria, your program must output the corresponding nicknames of the retrieved rows.
Input
The first line of input contains M (1 <= M <= 50), the number of rows on the table and N (1 <= N <= 20), the number of queries to be performed. The next M lines contain the rows of the table. Each row is completely described in a single line and contains four tokens separated by single space: Nickname, which is a string of length not exceeding 20; Country, an uppercase string of length 2 consisting of letters [A-Z]; CF_Rating, a positive integer in the range [0, 5000] and TC_Rating, similar to CF_Rating. Nicknames are not unique.
The following N lines contain the list of queries to be performed. Each query is described in a single line. The format of a query is as follows (without brackets):
[CF_Rating | TC_Rating] [ < | > | <= | >= ] [positive_integer] [AND | OR] [CF_Rating | TC_Rating] [ < | > | <= | >= ] [positive_integer].
Output
For each query i enumerated from 1 to N:
- output as its first line "Query #i:"
- output each nickname on a separate line
The list of nicknames must be printed in lexicographical order.
Examples
Input 6 2 tourist BY 3205 3693 Petr RU 2676 3738 Egor RU 2732 3463 cjtoribio DO 2019 1381 niquefa_diego CO 2059 1896 Un_Exisstin3 PE 2400 1499 CF_Rating < 2200 OR TC_Rating <= 1500 CF_Rating > 1 AND TC_Rating >= 3600</p>Output Query #1: Un_Exisstin3 cjtoribio niquefa_diego Query #2: Petr tourist