go VS zetasql

Compare go vs zetasql and see what are their differences.

go

Trealla Prolog embedded in Go using WASM (by trealla-prolog)

zetasql

ZetaSQL - Analyzer Framework for SQL (by google)
InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
go zetasql
5 15
72 2,135
- 0.4%
8.6 0.0
3 days ago about 2 months ago
Go C++
MIT License Apache License 2.0
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

go

Posts with mentions or reviews of go. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-01-07.
  • PHP: Prolog Home Page
    10 projects | news.ycombinator.com | 7 Jan 2023
    Hey, this is mine. Thanks for submitting it. I'll answer some questions.

    > Why?

    I ported Trealla Prolog to WASM (WASI) and I was looking for something useful to test it against. I found Spin, which can run WASM+CGI, and landed on this. Making this project exposed a number of bugs in my port that have now been fixed, so consumers of more useful projects[1][2] benefit as well. Also, PHP style templates are just fun! There's something valuable to just being able to shove a little bit of code inside some HTML and get it up on the internet.

    I started my webdev journey with PHP many many years ago, and it's nice to revisit it from a different perspective. I don't use the real (elephant) PHP anymore, but I've gained a newfound appreciation for how fun its quick & dirty development style is.

    I hope this project can serve as an example of how to use Prolog for fun things. It does showcase some of the cooler dynamic aspects of the language, and the PHP parsing code is like 10 lines of DCG.

    > Is it a joke?

    Yes and no. The name is certainly a joke. I was pondering what 'Prolog on Rails' might be and thought calling it PHP would be funny. This led to the PHP-style templates which were quick to implement and pretty powerful. Despite the humorous presentation, it does actually work.

    > Can you use Prolog for web services?

    Yes! For example, SWI has a mature HTTP package: https://www.swi-prolog.org/pldoc/doc_for?object=section(%27p.... It's used to power SWISH, an online Prolog code sharing thing: https://swish.swi-prolog.org/

    > Next steps?

    I would like to support persistence somehow. I think it'd be really cool if you could use Prolog's dynamic database[3] as a persistent store. Spin has components for Postgres and Redis so it shouldn't be too hard to implement, but I lose the WASI compatibility if I do that... which means I can't use the binary from WAPM, etc.

    I would also like to experiment with running Trealla on Cloudflare Workers. I have another project, worker-prolog[4], which uses Tau Prolog (a Prolog written in Javascript) on Workers.

    On a somewhat related note, I've also been playing around with Cosmopolitan libc[5]. I got Trealla to compile to an APE executable but there's some issues with the embedded Prolog libraries getting garbled, so I need to improve my GDB skills and figure out what's going on there.

    Finally, I'd like to say thanks to Andrew Davison (@infradig on GitHub), the author of Trealla Prolog, for letting me add WASM support to his project and helping me with lots of things. For example, PHP led to Andrew implementing improvements for using DCGs to parse Prolog terms, which is now super fast[6]!

    [1]: https://github.com/guregu/trealla-js

    [2]: https://github.com/trealla-prolog/go

    [3]: https://www.swi-prolog.org/pldoc/man?predicate=assertz/1

    [4]: https://github.com/guregu/worker-prolog

    [5]: https://justine.lol/cosmopolitan/

    [6]: https://github.com/trealla-prolog/trealla/issues/53

  • Prolog at work
    4 projects | /r/prolog | 28 Dec 2022
    With trealla-prolog/go on the backend and trealla-js on the frontend, you can share the same validation code.
  • Mangle, a programming language for deductive database programming
    12 projects | news.ycombinator.com | 26 Nov 2022
    Other resources for logic programming and Go:

    ichiban/prolog - ISO Prolog interpreter in pure Go, getting close to v1: https://github.com/ichiban/prolog

    trealla-prolog/go - ISO Prolog interpreter embedded via WASM: https://github.com/trealla-prolog/go

    guregu/pengine - library for interfacing with Pengines (SWI-Prolog's RPC protocol): https://github.com/guregu/pengine

    biscuit-auth/biscuit-go - Biscuits are a fancy auth token with a little Datalog engine: https://github.com/biscuit-auth/biscuit-go

    I'm a big fan of logic programming. We've been seeing a small resurgence of interest in it (for example Yarn using Prolog made some waves) and I have some optimism for its future.

  • The Carcinization of Go Programs
    4 projects | news.ycombinator.com | 23 Nov 2022
    Nice article! I think this is an exciting approach to cross-platform support. I took a similar approach for Trealla Prolog's Go library: https://github.com/trealla-prolog/go

    The biggest roadblock at the moment is that Go WASM libraries are not in a very good state, except wazero. My assumption is that wazero will be slower than the cranelift-optimized wasmtime, etc. but I have not seen any benchmarks anywhere.

    My impressions of the Go WASM libraries:

    wazero: great Go-friendly API, not sure about performance, works on all OS (what the author chose)

    wasmer: provides bare-minimum input and output for WASI, fast (it's what I chose for trealla-go). Doesn't work on Windows without significant pain, doesn't static compile the wasmer libraries so distribution is a pain. Seems essentially abandoned as its main contributor left the company.

    wasmtime: basically impossible to get input and output in any reasonable way (unable to set stdin or read stdout; it can only inherit the FDs from the host), but might finally get buffers for I/O soon.

    wasmedge: haven't investigated this yet, but it seems like it solves many of the problems above, promising

    If anyone knows of a benchmark between these, I'd love to see it. I can try to run Trealla's against them if it doesn't take too much work.

  • Trealla – A compact, efficient Prolog interpreter written in plain-old C
    4 projects | news.ycombinator.com | 7 Aug 2022
    It was just made private, I guess. Only the Go WebAssembly project is still public: https://github.com/trealla-prolog/trealla-go

zetasql

Posts with mentions or reviews of zetasql. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2022-11-26.
  • Mangle, a programming language for deductive database programming
    12 projects | news.ycombinator.com | 26 Nov 2022
    There are even table-valued functions.

    These things are not widespread, and differ by implementation, and the way these are used by clients are copy-and-paste. Something as thoughtful as ZetaSQL https://github.com/google/zetasql does not have mechanisms for structuring (modules, packages, interfaces). SQL will not, cannot evolve into such a direction (or, anything that evolves, will not be recognizable as SQL).

  • goccy/bigquery-emulator: BigQuery emulator server implemented in Go
    2 projects | /r/bigquery | 17 Oct 2022
    Hi, I develop a BigQuery emulator ( https://github.com/goccy/bigquery-emulator ) from early 2022. It is written in Go, but can be used from bq command line tool and other language's (e.g. Python ) client SDK after installing docker image or released binary. It currently supports over 200 of the nearly 330 standard functions in BigQuery and all data types except GEOGRAPHY ( see https://github.com/goccy/go-zetasqlite#status for details ). ZetaSQL ( https://github.com/google/zetasql ) is used to parse and analyze queries.
  • ZetaSQL – Analyzer Framework for SQL
    1 project | news.ycombinator.com | 13 Oct 2022
  • ZetaSQL - Question about using local service
    1 project | /r/bigquery | 10 Oct 2022
    We are using a Python client binding for ZetaSQL GRPC local service in our application to analyze statements and extract referenced tables and output columns.
  • Parsing SQL
    7 projects | news.ycombinator.com | 22 Aug 2022
    If you don't want to do it yourself, there's this:

    https://github.com/google/zetasql

    Parsing is huge but it's amazing how small a part of the job it is. This library isn't even the half of it.

  • SQLGlot: SQL parser, transpiler, optimizer – translate to Presto, Spark, Hive
    9 projects | news.ycombinator.com | 4 Jul 2022
  • ZetaSQL - Analyzer Framework for SQL
    1 project | /r/CKsTechNews | 13 Oct 2021
  • ZetaSQL
    1 project | news.ycombinator.com | 12 Oct 2021
  • New PostgreSQL Interface for Cloud Spanner
    2 projects | news.ycombinator.com | 12 Oct 2021
    I mean the postgres parser (and semantic changes) for ZetaSQL. The zetasql parser is in a file called zetasql/parser/bison_parser.y, I strongly suspect they now have a file called something like zetasql/pgparser/bison_parser.y as well (and much more pervasive changes to support the deeper differences in the dialects).

    This is the lexical structure and syntax docs for the new postgres inteface to cloud spanner:

    https://cloud.google.com/spanner/docs/postgresql/lexical

    And this is the zetasql lexical structure and syntax docs:

    https://github.com/google/zetasql/blob/master/docs/lexical.m...

    Notice that the new PG docs are an edit of the Zeta ones - evidence that my hypothesis is correct.

  • Open Source SQL Parsers
    17 projects | dev.to | 8 Oct 2021
    zetasql implements BigQuery, Spanner, and Dataflow dialects.

What are some alternatives?

When comparing go and zetasql you can also consider the following projects:

ciao - Ciao is a modern Prolog implementation that builds up from a logic-based simple kernel designed to be portable, extensible, and modular.

sqlparse - A non-validating SQL parser module for Python

packages-http - The SWI-Prolog HTTP server and client libraries

Apache Calcite - Apache Calcite

php - Prolog Home Page

JSqlParser - JSqlParser parses an SQL statement and translate it into a hierarchy of Java classes. The generated hierarchy can be navigated using the Visitor Pattern

mangle

ANTLR - ANTLR (ANother Tool for Language Recognition) is a powerful parser generator for reading, processing, executing, or translating structured text or binary files.

trealla-js - Trealla Prolog for the web

pgsql-parser - PostgreSQL Query Parser for Node.js

wazero - wazero: the zero dependency WebAssembly runtime for Go developers

sqlite-parser - JavaScript implentation of SQLite 3 query parser