Quantcast
Channel: SAP HANA Central
Viewing all articles
Browse latest Browse all 711

sqlpad meets SAP HANA

$
0
0
Having already contacted the author of the project, Rick, he was open to the idea of a contribution so a fork in Github later and a few alternations to the codebase and I was ready to proceed. The internal process was pretty quick, took me just a couple of days while a simple form was processed (time zones delay everything!).

SAP HANA Tutorials and Materials, SAP HANA Certifications, SAP HANA Learning, SAP HANA SQL
SAP HANA Tutorials and Materials, SAP HANA Certifications, SAP HANA Learning, SAP HANA SQL

All checks were green! Now to wait for the pull request to be merged and see how things go! I’ve always found it amazing how a small amount code changes can make to the overall functionality of a program.

SAP HANA Tutorials and Materials, SAP HANA Certifications, SAP HANA Learning, SAP HANA SQL

8 files, a few lines and a whole new database is supported!

SAP HANA Tutorials and Materials, SAP HANA Certifications, SAP HANA Learning, SAP HANA SQL

The coolest part of course is watching your request get merged!

SAP HANA Tutorials and Materials, SAP HANA Certifications, SAP HANA Learning, SAP HANA SQL

To top it off I just got an email this morning where Rick let me know that he has deployed the latest version to “npm” so you can now officially get your hands on it and connect it to your SAP HANA systems!

Looks like I may need to submit a change or two to the docs for the program in general but functionality wise we are set to go so far! So I wanted to share 3 ways you can get your hands on the program.

◈ Direct install
◈ Vagrant
◈ Docker

The direct install, well all of them are pretty straight forward. For this one you will need to have Node JS installed (version 6.0.0 is what I have done all my testing and usage with).

SAP HANA Tutorials and Materials, SAP HANA Certifications, SAP HANA Learning, SAP HANA SQL

At your command prompt/terminal you can execute “npm install sqlpad -g”

SAP HANA Tutorials and Materials, SAP HANA Certifications, SAP HANA Learning, SAP HANA SQL

To run it just type “sqlpad”, granted you will probably want to add parameters, etc

SAP HANA Tutorials and Materials, SAP HANA Certifications, SAP HANA Learning, SAP HANA SQL

The second option I played with is Vagrant, which I mentioned in my previous post about my system issues. My Vagrant file looks like:

# -*- mode: ruby -*-
# vi: set ft=ruby :
$rootScript = <<SCRIPT
sudo locale-gen "en_US.UTF-8"
sudo dpkg-reconfigure locales
sudo apt-get install -y git-core curl
SCRIPT

$userScript = <<SCRIPT
  cd /home/vagrant
  mkdir /home/vagrant/sqlpaddb

  # Installing nvm
  wget -qO- https://raw.github.com/creationix/nvm/master/install.sh | sh

  # This enables NVM without a logout/login
  export NVM_DIR="/home/vagrant/.nvm"
  [ -s "$NVM_DIR/nvm.sh" ] && . "$NVM_DIR/nvm.sh"  # This loads nvm

  echo "Installing: "
  echo "Application:  node.js"
  nvm install stable &> /dev/null
  nvm install 6.0.0
  nvm alias default 6.0.0
  npm install -g npm

  # Install sqlpad
  npm install sqlpad -g
  
  sqlpad --dir /home/vagrant/sqlpaddb/ --port 3000 &> start.log & echo "SQL Pad started"
  #/home/vagrant/.nvm/versions/node/v6.0.0/bin/sqlpad --dir /home/vagrant/sqlpaddb/ --port 3000 &> start.log
  #/usr/sbin/node /home/vagrant/.nvm/versions/node/v6.0.0/lib/node_modules/sqlpad/server.js --dir /home/vagrant/sqlpaddb/ --port 3000 &> start.log
SCRIPT

ENV["LC_ALL"] = "en_US.UTF-8"
Vagrant.configure("2") do |config|
  config.vm.box = "ubuntu/xenial64"
  config.vm.provision "shell", inline: $rootScript
  config.vm.provision "shell", inline: $userScript, privileged: false
  config.vm.network "forwarded_port", guest: 3000, host: 3000, host_ip: "127.0.0.1"
  config.vm.network "forwarded_port", guest: 3010, host: 3010, host_ip: "127.0.0.1"
  config.vm.provider "virtualbox" do |vb|
    # Customize the amount of memory on the VM:
    vb.memory = "2048"
  end
end

This puts everything self contained into a VM.

The final option which i lean towards the most is my Docker config. Which puts my configuration for the program locally (I make sure it’s in a sync’d folder).

My “docker-compose.yml” file looks like:

version: '3'

services:
  app:
    build:
      context: .
    volumes:
      - db-data:/opt/data
    ports:
      - "3000:3000"
volumes:
  db-data:

My “DockerFile” looks like:

FROM node:6.0.0
RUN apt-get update
RUN apt-get install -y less
RUN npm install
RUN npm install sqlpad -g  

RUN mkdir -p /opt/data/
COPY ./db /opt/data/

EXPOSE 3000
CMD ["sh", "-c", "/usr/local/bin/sqlpad --dir /opt/data --port 3000"]

Regardless of which of these methods or another method once it’s up an running here you go. Once you have either signed in or signed up you can add your connection.

SAP HANA Tutorials and Materials, SAP HANA Certifications, SAP HANA Learning, SAP HANA SQL

Now I added the IP of my SAP HANA express system to my hosts file so I could just put the hostname.

SAP HANA Tutorials and Materials, SAP HANA Certifications, SAP HANA Learning, SAP HANA SQL

Now by leaving the “schema” blank I’m not tying the connection to anything specific, I can also give a specific “schema” as well.

SAP HANA Tutorials and Materials, SAP HANA Certifications, SAP HANA Learning, SAP HANA SQL

SAP HANA Tutorials and Materials, SAP HANA Certifications, SAP HANA Learning, SAP HANA SQL

Once I have my system connection I can start running queries.

SAP HANA Tutorials and Materials, SAP HANA Certifications, SAP HANA Learning, SAP HANA SQL

SAP HANA Tutorials and Materials, SAP HANA Certifications, SAP HANA Learning, SAP HANA SQL

To quickly test things I decided to check very quickly how my system was running.

SAP HANA Tutorials and Materials, SAP HANA Certifications, SAP HANA Learning, SAP HANA SQL

Saving the queries make life easy because I can re run favorite queries anytime.

SAP HANA Tutorials and Materials, SAP HANA Certifications, SAP HANA Learning, SAP HANA SQL

The data visualization is awesome, just not with this particular query.

SAP HANA Tutorials and Materials, SAP HANA Certifications, SAP HANA Learning, SAP HANA SQL

Lightweight, easy to use and extensible – what more can you want from a tool? Now granted I’m sure many people are scratching their heads and saying “but but but” and yes SAP has their own tools, however if you are going after the “Server Only” version of SAP HANA express edition those tool choices are limited and limitations are not something I am a fan of so I decided to add another option to the mix.

Viewing all articles
Browse latest Browse all 711

Trending Articles



<script src="https://jsc.adskeeper.com/r/s/rssing.com.1596347.js" async> </script>