CenSQL (Pronounced "Sen-Sea-Quel") is an unofficial replacement by Centiq Ltd for the hdbsql CLI. It was created to provided command history and shorthand commands useful for monitoring SAP HANA which aren't available in the hdbsql client.
As well as having a smoother user interface, CenSQL also provides a lot more functionality which is not present in hdbsql, such as shortcuts for sql queries useful for any DB admin or developer for example \al
for viewing open alerts on the instance you are connected to.
Finally, CenSQL has support for bar charts and line graphs inside the CLI interface for showing a 'at-a-glance' view of the status and history of the instance, for example \cpu
for showing the CPU usage for each host for the instance and \smem
for showing the current shared memory.
See an SCN article about CenSQL
Note: CenSQL has been tested on Ubuntu, Debian, SLES, SLES4SAP, Windows Server 2003 and Windows 7/8 Desktop. It most likely works perfectly on OSX but no testing is done on this platform.
- Install NodeJS v0.10.30 or higher (If not already installed)
sudo npm install -g censql
censql --help
sudo npm install -g nexe
git clone git@github.com:Centiq/CenSQL.git
cd CenSQL
npm install
nexe
./censql --help
orcensql.exe --help
Entering a SQL query is done by simply typing it in and pressing enter.
> SELECT HOST, UNLOAD_TIME, SCHEMA_NAME FROM SYS.M_CS_UNLOADS LIMIT 2
HOST | UNLOAD_TIME | SCHEMA_NAME
- - - - - - - - - - - - - - - - - - -
hananode01 | 2015-07-02T05:30:34.017 | _SYS_STATISTICS
hananode01 | 2015-07-02T05:30:34.006 | _SYS_STATISTICS
Results will be returned in a table format unless the command is ended with '\G' in which case it will draw data in a grouped format
> SELECT HOST, UNLOAD_TIME, SCHEMA_NAME FROM SYS.M_CS_UNLOADS LIMIT 2\G
No: 0 -------------------
HOST: hananode01
UNLOAD_TIME: 2015-07-02T05:30:34.017
SCHEMA_NAME: _SYS_STATISTICS
No: 1 -------------------
HOST: hananode01
UNLOAD_TIME: 2015-07-02T05:30:34.006
SCHEMA_NAME: _SYS_STATISTICS
Any CenSQL command is prefixed with a '\'. This stops the input from being sent directly to HANA and instead runs the CenSQL command.
> \st
HOST | HOST_ACTIVE | HOST_STATUS
- - - - - - - - - - - - - - - - - - -
hananode01 | YES | OK
Output from any query or command may be piped to a post command which will transform the output in some way. eg:
> \serv | grep indexserver
hananode01 | 30103 | indexserver | 4771 | master | YES | 30115 | MASTER
$ censql --user SYSTEM --port 34315 --host 192.168.182.240 --pass Passw0rd --command "\st"
HOST | HOST_ACTIVE | HOST_STATUS
- - - - - - - - - - - - - - - - - - -
dev-kvmhana01 | YES | OK
dev-kvmhana02 | YES | OK
$ censql --use MY_SAVED_INSTANCE --command "\st\j"
[{"HOST":"dev-hana01","HOST_ACTIVE":"YES","HOST_STATUS":"OK"},{"HOST":"dev-hana02","HOST_ACTIVE":"YES","HOST_STATUS":"OK"}]
License: MIT