Git Product home page Git Product logo

in-mem-db's Introduction

in-mem-db

In Memory Database - A popular assignment question I found Interesting.

Problem Statement:

Programming Assignment: Simple Database

Implement an in-memory database. Your program will receive commands via standard input (stdin) and should write appropriate responses to standard output (stdout). You can use high-level languages such as Python, Ruby, Java, C#, …, etc.

Your database should accept the following commands:

SET name value – Set the variable name to the value. Neither variable names nor values will contain spaces.

GET name – Print out the value of the variable name, or NULL if that variable is not set.

UNSET name – Unset the variable name, making it just like that variable was never set.

NUMEQUALTO value – Print out the number of variables that are currently set to value. If no variables equal that value, print 0.

ADD name value – Add the value to variable name, or NULL if that variable name is not set.

ADD name1 name2 – Add the value of variable name2 to variable name1, or NULL if that any variable name is not set.

END – Exit the program.

Your program will always receive this as its last command. Commands will be fed to your program one at a time, with each command on its own line. Any output that your program generates should end with a newline character.

Here are some example command sequences:

INPUT      OUTPUT

SET x 10

GET x         10

UNSET x

GET x         NULL

END


INPUT      OUTPUT

SET a 10

SET b 10

NUMEQUALTO 10     2

NUMEQUALTO 20     0

SET b 30

NUMEQUALTO 10     1

END


Transaction Commands In addition to the above data commands, your program should also support database transactions by also implementing these commands:

BEGIN – Open a new transaction block. Transaction blocks can be nested; a BEGIN can be issued inside of an existing block.

ROLLBACK – Undo all of the command’s issues in the most recent transaction block, and close the block. Print nothing if successful or print NO TRANSACTION if no transaction is in progress.

COMMIT – Close all open transaction blocks, permanently applying the changes made in them. Print nothing if successful or print NO TRANSACTION if no transaction is in progress. Any data command that is run outside of a transaction block should commit immediately.

Here are some example command sequences:


INPUT      OUTPUT

BEGIN

SET a 10

GET a         10

BEGIN

SET a 20

GET a         20

ROLLBACK

GET a         10

ROLLBACK

GET a         NULL

END


INPUT      OUTPUT

BEGIN

SET a 30

BEGIN

SET a 40

COMMIT

GET a         40

ROLLBACK       NO TRANSACTION

END

in-mem-db's People

Contributors

j-varma avatar

Stargazers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.