Constructing SQL Query Statements

Structured Query Language (SQL) is a standard computer language for accessing and managing databases. SuperMap uses SQL to build SQL expressions for data query. Generally, the syntax of the SQL expression is select OuputField from DatasetName where QueryCondition (order by OrderField ascending/descending). The OuputField, DatasetName and Order_Field can be directly selected from the list or drop-down list in the SQL Query dialog box, while the where clause needs to be built by us. In this section, some commonly used query expressions are introduced.

Please note that the wildcards may be different when building SQL expressions for file and database datasources because the attribute information of the file datasources are stored in Access format.

Numeric query

The numeric query can make use of the operators like ”=”, ”<>”, ”>”, ”<”, ”<=”, ”>=” and keyword of “BETWEEN…AND”.

For example:

World.Pop_1994 Between 10000000 and 20000000

Queries the World with the population between 10000000 and 20000000 in 1994.

Fuzzy query

The fuzzy query uses the keyword “LIKE”. The wildcards for different types of data sources are different.

For example:

(1) Partial match employs the wildcard of ”*” ( The wildcards for database and UDB datasources are ’%’ ).

World_World.CAPITAL Like “a*” and World.CAPITAL like ‘a%’

Query the World with their names begin with “a”.

(2) Fully match ( Database datasources can only use the single quotation marks, UDB datasources can use both single and double quotation mark ).

World_World.CAPITAL Like “Beijing”, World.CAPITAL like ‘Beijing’

Query the country with the capital of “Beijing”.

(3) Single character match employs the wildcard of ”?” ( The wildcards for database and UDB datasources are ’_’ ).

World.CAPITAL like ‘A_’

Query the records where the ISO2 field value is only two-character and must start with A in WorldWorld dataset.

Query specified value

The keyword “in” is used to determine whether the value of the expression is equivalent to any value in the specified list.

For example:

WorldWorld.ISO2 in (‘AD’,‘BS’,‘PH’)

Queries the World with the values of AD, BS and PH in the ISO_2 field.

World.SmID in (1,4)

Queries the World with the the values of 1 and 4 in the SmID field.

For character fields, the query values must be bracketed with a pair of single quotation marks or double quotation marks. While the numeric values don’t need quotation marks. For database datasources, the query values can only be bracketed with a pair of single quotation marks.

Query null value

The keyword is NULL (is not NULL) is used.

For example:

World.CAPITAL Is NULL

Queries the records with null value in the CAPITAL field. (It is likely that certain World haven’t been specified the capital name.)

Query by building expressions

For example:

World.SmArea > World.SmPerimeter * 50000

Queries the World with the area greater than 50,000 times of the perimeter.

The brackets can be used to arrange the priority. For example:

World.POP_1994 / (World.SmArea/1000000) > 500

Queries the World where the population per square kilometer is greater than 500 in 1994.

Query by combining expressions

Use “and”, “or”, or “not” to combine any expressions.

For example:

World.SmArea > 5000000000000 AND World.POP_1994 < 100000000

Queries the World with the area greater than 5,000,000 square kilometers and the population less than 100 million in 1994.

Apply comparison operators in string query

The comparison operators include ”>”, ”<”, ”>=”, ”<=”, ”<>”, etc.

For example:

World_World.NAME >= ‘N’

Queries the World with the name starting from N to Z. For database datasources, the query values can only be bracketed with a pair of single quotation marks.

Query date values

Create a date field named DataDate for the dataset Province_R to save the statistical time of each data. The following content details how to query date-type fields in common database-based datasource.

  • For the SQL(SQL+) datasource, to query all records that the value of the field DataDate is 2019-08-10 from the dataset ProvinceR, the expression should be ProvinceR.DataDate = ‘2019-08-10 12:25:00’;
  • For the ORACLE-based datasource, to query all records that the value of the field DataDate is 2019-08-10 from the dataset ProvinceR, the expression should be ProvinceR.DataDate > TO_DATE(‘2019-08-10’,‘YYYY-MM-DD’);
  • For the PostGIS-based datasource, to query all records that the value of the field DataDate is 2019-08-10 from the dataset ProvinceR, the expression should be “ProvinceR”.datadate < ‘2019-08-10 12:25:00’;
  • For the PostgreSQL-based datasource, to query all records of 2019 from the dataset ProvinceR, the expression should be ProvinceR.datadate between ‘2019-01-01 0:0:0’ and ‘2019-12-31 0:0:0’;
  • For the UDB/UDBX datasource, to query all records that include 2019 from the dataset ProvinceR, the expression should be ProvinceR.datadateProvince_R.DataDate Like ‘2019%‘;

Boolean Field Query

Boolean field value is either True or False. For SQL query, 1 represents True and 0 represents False.

For example:

City_R.Coastal = 1

Quries cities along the sea in City_R dataset.

Temporary field

For example:

Pop_1994 / SmArea

The temporary filed will be listed in the attribute table of the query results. You can also specify an alias for the temporary field, as shown below.

Pop1994/ SmArea as PopDensity

The alias is displayed on column heading in the attribute table to mark the corresponding field. The expression will be used if you don’t specify an alias for a temporary field. Use the comma to separate temporary fields if you want to define many.

Notes

When querying the Double, and using ”=”, you may not get the result because of the precision. It isn’t recomended for users to use ”=“.