Giter Club home page Giter Club logo

pocketsql's Introduction

Build Status Latest Nuget

PocketSql

An in-process implementation of T-SQL, packaged as a library, suitable for testing data acess code and queries.

Planned/Implemented Features

  • create, alter, drop for
    • Tables
    • Views
    • Procedures
    • Functions
      • Scalar
      • Table-valued
  • select, update, insert, delete, truncate, merge with
    • output for DML statements
    • offset ... fetch for queries
    • select ... into
    • insert ... select
    • update ... join
    • distinct
  • CTEs (Common Table Expressions)
  • if, while statments
  • case, between expressions
  • try, catch, throw, error_* functions
  • All binary operators
  • sum, count, rownumber aggregate functions
  • Calling user-defined functions
  • Input, output and return parameters
  • declare, set, access local variables
  • Global variables
    • @@rowcount, @@fetch_status, @@identity, @@error
  • Cursors
  • Uniqueness constraints imposed by indexes
  • identity auto-incrementing columns
    • constraints imposed by it
    • ability to set indentity insert on and off
  • default values for columns
  • implicit type conversions and type checking

Currently Unplanned/Excluded Features

  • waitfor
  • break, continue, goto, labels
  • Working Transactions with rollback/commit
  • Nested table results
  • Customizable collations (everything is case insensitive by default)
  • Backup/restore capability
  • INFORMATION_SCHEMA and other control tables and procedures
  • Optimizations around indexes
  • for keyword that specifies output format
  • XML types and namespaces
  • any special handling of the go statement
  • Query plan caching
  • Ability to report query plan

pocketsql's People

Contributors

rkoeninger avatar markewer 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.