blob: c9a3af9dd8e0f24a3f7c18b54a32ec9c0aa75331 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
const Util = require('util');
const {IgniteClient, ObjectType, CacheConfiguration, SqlFieldsQuery, SqlQuery, IgniteClientConfiguration} = require('apache-ignite-client');
const ENDPOINT = '127.0.0.1:10800';
const COUNTRY_CACHE_NAME = 'Country';
const CITY_CACHE_NAME = 'City';
const COUNTRY_LANGUAGE_CACHE_NAME = 'CountryLng';
const DUMMY_CACHE_NAME = 'SqlExample_Dummy';
// This example shows primary APIs to use with Ignite as with an SQL database:
// - connects to a node
// - creates a cache, if it doesn't exist
// - creates tables (CREATE TABLE)
// - creates indices (CREATE INDEX)
// - writes data of primitive types into the tables (INSERT INTO table)
// - reads data from the tables (SELECT ...)
// - deletes tables (DROP TABLE)
// - destroys the cache
class SqlExample {
async start() {
const igniteClient = new IgniteClient(this.onStateChanged.bind(this));
try {
await igniteClient.connect(new IgniteClientConfiguration(ENDPOINT));
const cache = await igniteClient.getOrCreateCache(
DUMMY_CACHE_NAME,
new CacheConfiguration().setSqlSchema('PUBLIC'));
await this.createDatabaseObjects(cache);
await this.insertData(cache);
const countryCache = igniteClient.getCache(COUNTRY_CACHE_NAME);
const cityCache = igniteClient.getCache(CITY_CACHE_NAME);
await this.getMostPopulatedCities(countryCache);
await this.getTopCitiesInThreeCountries(cityCache);
await this.getCityDetails(cityCache, 5);
await this.deleteDatabaseObjects(cache);
await igniteClient.destroyCache(DUMMY_CACHE_NAME);
}
catch (err) {
console.log('ERROR: ' + err.message);
}
finally {
igniteClient.disconnect();
}
}
async createDatabaseObjects(cache) {
const createCountryTable = `CREATE TABLE Country (
Code CHAR(3) PRIMARY KEY,
Name CHAR(52),
Continent CHAR(50),
Region CHAR(26),
SurfaceArea DECIMAL(10,2),
IndepYear SMALLINT(6),
Population INT(11),
LifeExpectancy DECIMAL(3,1),
GNP DECIMAL(10,2),
GNPOld DECIMAL(10,2),
LocalName CHAR(45),
GovernmentForm CHAR(45),
HeadOfState CHAR(60),
Capital INT(11),
Code2 CHAR(2)
) WITH "template=partitioned, backups=1, CACHE_NAME=${COUNTRY_CACHE_NAME}"`;
const createCityTable = `CREATE TABLE City (
ID INT(11),
Name CHAR(35),
CountryCode CHAR(3),
District CHAR(20),
Population INT(11),
PRIMARY KEY (ID, CountryCode)
) WITH "template=partitioned, backups=1, affinityKey=CountryCode, CACHE_NAME=${CITY_CACHE_NAME}"`;
const createCountryLanguageTable = `CREATE TABLE CountryLanguage (
CountryCode CHAR(3),
Language CHAR(30),
IsOfficial CHAR(2),
Percentage DECIMAL(4,1),
PRIMARY KEY (CountryCode, Language)
) WITH "template=partitioned, backups=1, affinityKey=CountryCode, CACHE_NAME=${COUNTRY_LANGUAGE_CACHE_NAME}"`;
// create tables
(await cache.query(new SqlFieldsQuery(createCountryTable))).getAll();
(await cache.query(new SqlFieldsQuery(createCityTable))).getAll();
(await cache.query(new SqlFieldsQuery(createCountryLanguageTable))).getAll();
// create indices
(await cache.query(new SqlFieldsQuery(
'CREATE INDEX idx_country_code ON city (CountryCode)'))).getAll();
(await cache.query(new SqlFieldsQuery(
'CREATE INDEX idx_lang_country_code ON CountryLanguage (CountryCode)'))).getAll();
console.log('Database objects created');
}
async insertData(cache) {
const cities = [
['New York', 'USA', 'New York', 8008278],
['Los Angeles', 'USA', 'California', 3694820],
['Chicago', 'USA', 'Illinois', 2896016],
['Houston', 'USA', 'Texas', 1953631],
['Philadelphia', 'USA', 'Pennsylvania', 1517550],
['Moscow', 'RUS', 'Moscow (City)', 8389200],
['St Petersburg', 'RUS', 'Pietari', 4694000],
['Novosibirsk', 'RUS', 'Novosibirsk', 1398800],
['Nizni Novgorod', 'RUS', 'Nizni Novgorod', 1357000],
['Jekaterinburg', 'RUS', 'Sverdlovsk', 1266300],
['Shanghai', 'CHN', 'Shanghai', 9696300],
['Peking', 'CHN', 'Peking', 7472000],
['Chongqing', 'CHN', 'Chongqing', 6351600],
['Tianjin', 'CHN', 'Tianjin', 5286800],
['Wuhan', 'CHN', 'Hubei', 4344600]
];
const cityQuery = new SqlFieldsQuery(`INSERT INTO City(ID, Name, CountryCode, District, Population)
VALUES (?, ?, ?, ?, ?)`);
for (let i = 0; i < cities.length; i++) {
(await cache.query(cityQuery.setArgs(i, ...cities[i]))).getAll();
}
const countries = [
['USA', 'United States', 'North America', 'North America',
9363520.00, 1776, 278357000, 77.1, 8510700.00, 8110900.00,
'United States', 'Federal Republic', 'George W. Bush', 3813, 'US'],
['RUS', 'Russian Federation', 'Europe', 'Eastern Europe',
17075400.00, 1991, 146934000, 67.2, 276608.00, 442989.00,
'Rossija', 'Federal Republic', 'Vladimir Putin', 3580, 'RU'],
['CHN', 'China', 'Asia', 'Eastern Asia',
9572900.00, -1523, 1277558000, 71.4, 982268.00, 917719.00,
'Zhongquo', 'PeoplesRepublic', 'Jiang Zemin', 1891, 'CN']
];
const countryQuery = new SqlFieldsQuery(`INSERT INTO Country(
Code, Name, Continent, Region, SurfaceArea,
IndepYear, Population, LifeExpectancy, GNP, GNPOld,
LocalName, GovernmentForm, HeadOfState, Capital, Code2)
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`);
for (let country of countries) {
(await cache.query(countryQuery.setArgs(...country))).getAll();
}
console.log('Data are inserted');
}
async getMostPopulatedCities(countryCache) {
const query = new SqlFieldsQuery(
'SELECT name, population FROM City ORDER BY population DESC LIMIT 10');
const cursor = await countryCache.query(query);
console.log("10 Most Populated Cities:");
let row;
do {
row = await cursor.getValue();
console.log(" " + row[1] + " people live in " + row[0]);
} while (cursor.hasMore());
}
async getTopCitiesInThreeCountries(countryCache) {
const query = new SqlFieldsQuery(
`SELECT country.name, city.name, MAX(city.population) as max_pop FROM country
JOIN city ON city.countrycode = country.code
WHERE country.code IN ('USA','RUS','CHN')
GROUP BY country.name, city.name ORDER BY max_pop DESC LIMIT 3`);
const cursor = await countryCache.query(query);
console.log("3 Most Populated Cities in US, RUS and CHN:");
for (let row of await cursor.getAll()) {
console.log(" " + row[2] + " people live in " + row[1] + ", " + row[0]);
}
}
async getCityDetails(cityCache, cityId) {
const query = new SqlFieldsQuery('SELECT * FROM City WHERE id = ?').
setArgs(cityId);
const cursor = await cityCache.query(query);
const fieldNames = cursor.getFieldNames();
for (let city of await cursor.getAll()) {
console.log('City Info:');
for (let column of city) {
console.log(" " + column);
}
}
}
async deleteDatabaseObjects(cache) {
(await cache.query(new SqlFieldsQuery('DROP TABLE IF EXISTS Country'))).getAll();
(await cache.query(new SqlFieldsQuery('DROP TABLE IF EXISTS City'))).getAll();
(await cache.query(new SqlFieldsQuery('DROP TABLE IF EXISTS CountryLanguage'))).getAll();
console.log('Database objects dropped');
}
onStateChanged(state, reason) {
if (state === IgniteClient.STATE.CONNECTED) {
console.log('Client is started');
}
else if (state === IgniteClient.STATE.DISCONNECTED) {
console.log('Client is stopped');
if (reason) {
console.log(reason);
}
}
}
}
const sqlExample = new SqlExample();
sqlExample.start();