{"id":39665895,"url":"https://github.com/de-jaggl/sqlbuilder","last_synced_at":"2026-01-18T09:31:36.469Z","repository":{"id":57730608,"uuid":"230503149","full_name":"de-jaggl/sqlbuilder","owner":"de-jaggl","description":"A Java-Library to build SQL-Statements","archived":false,"fork":false,"pushed_at":"2020-08-26T09:57:19.000Z","size":541,"stargazers_count":6,"open_issues_count":0,"forks_count":0,"subscribers_count":2,"default_branch":"master","last_synced_at":"2023-07-26T23:16:09.665Z","etag":null,"topics":["java-library","mysql","sql","sql-builder","sql-statements","sqlbuilder","sybase","sybase-sql"],"latest_commit_sha":null,"homepage":null,"language":"Java","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/de-jaggl.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2019-12-27T19:15:11.000Z","updated_at":"2022-09-23T07:50:59.000Z","dependencies_parsed_at":"2022-09-26T22:01:28.400Z","dependency_job_id":null,"html_url":"https://github.com/de-jaggl/sqlbuilder","commit_stats":null,"previous_names":[],"tags_count":24,"template":null,"template_full_name":null,"purl":"pkg:github/de-jaggl/sqlbuilder","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/de-jaggl%2Fsqlbuilder","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/de-jaggl%2Fsqlbuilder/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/de-jaggl%2Fsqlbuilder/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/de-jaggl%2Fsqlbuilder/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/de-jaggl","download_url":"https://codeload.github.com/de-jaggl/sqlbuilder/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/de-jaggl%2Fsqlbuilder/sbom","scorecard":{"id":330533,"data":{"date":"2025-08-11","repo":{"name":"github.com/de-jaggl/sqlbuilder","commit":"d2b3ddeaf22f8d71f861723424100f388e4cbdbe"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":3.1,"checks":[{"name":"Maintained","score":0,"reason":"0 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#maintained"}},{"name":"Code-Review","score":0,"reason":"Found 0/26 approved changesets -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#code-review"}},{"name":"Dangerous-Workflow","score":10,"reason":"no dangerous workflow patterns detected","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#dangerous-workflow"}},{"name":"Token-Permissions","score":0,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Warn: no topLevel permission defined: .github/workflows/nightly.yml:1","Warn: no topLevel permission defined: .github/workflows/release.yml:1","Warn: no topLevel permission defined: .github/workflows/review.yml:1","Info: no jobLevel write permissions found"],"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#token-permissions"}},{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#binary-artifacts"}},{"name":"Pinned-Dependencies","score":0,"reason":"dependency not pinned by hash detected -- score normalized to 0","details":["Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/nightly.yml:13: update your workflow using https://app.stepsecurity.io/secureworkflow/de-jaggl/sqlbuilder/nightly.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/nightly.yml:18: update your workflow using https://app.stepsecurity.io/secureworkflow/de-jaggl/sqlbuilder/nightly.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/nightly.yml:21: update your workflow using https://app.stepsecurity.io/secureworkflow/de-jaggl/sqlbuilder/nightly.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.yml:16: update your workflow using https://app.stepsecurity.io/secureworkflow/de-jaggl/sqlbuilder/release.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.yml:27: update your workflow using https://app.stepsecurity.io/secureworkflow/de-jaggl/sqlbuilder/release.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.yml:34: update your workflow using https://app.stepsecurity.io/secureworkflow/de-jaggl/sqlbuilder/release.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.yml:37: update your workflow using https://app.stepsecurity.io/secureworkflow/de-jaggl/sqlbuilder/release.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/review.yml:13: update your workflow using https://app.stepsecurity.io/secureworkflow/de-jaggl/sqlbuilder/review.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/review.yml:18: update your workflow using https://app.stepsecurity.io/secureworkflow/de-jaggl/sqlbuilder/review.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/review.yml:21: update your workflow using https://app.stepsecurity.io/secureworkflow/de-jaggl/sqlbuilder/review.yml/master?enable=pin","Info:   0 out of   9 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of   1 third-party GitHubAction dependencies pinned"],"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#pinned-dependencies"}},{"name":"CII-Best-Practices","score":0,"reason":"no effort to earn an OpenSSF best practices badge detected","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#cii-best-practices"}},{"name":"Security-Policy","score":0,"reason":"security policy file not detected","details":["Warn: no security policy file detected","Warn: no security file to analyze","Warn: no security file to analyze","Warn: no security file to analyze"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#security-policy"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#fuzzing"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Info: FSF or OSI recognized license: MIT License: LICENSE:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#license"}},{"name":"Packaging","score":-1,"reason":"packaging workflow not detected","details":["Warn: no GitHub/GitLab publishing workflow detected."],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#packaging"}},{"name":"Signed-Releases","score":0,"reason":"Project has not signed or included provenance with any releases.","details":["Warn: release artifact 2.7.2 not signed: https://api.github.com/repos/de-jaggl/sqlbuilder/releases/30147797","Warn: release artifact 2.7.1 not signed: https://api.github.com/repos/de-jaggl/sqlbuilder/releases/26466494","Warn: release artifact 2.7.0 not signed: https://api.github.com/repos/de-jaggl/sqlbuilder/releases/26302821","Warn: release artifact 2.6.9 not signed: https://api.github.com/repos/de-jaggl/sqlbuilder/releases/25908230","Warn: release artifact 2.6.8 not signed: https://api.github.com/repos/de-jaggl/sqlbuilder/releases/25851463","Warn: release artifact 2.7.2 does not have provenance: https://api.github.com/repos/de-jaggl/sqlbuilder/releases/30147797","Warn: release artifact 2.7.1 does not have provenance: https://api.github.com/repos/de-jaggl/sqlbuilder/releases/26466494","Warn: release artifact 2.7.0 does not have provenance: https://api.github.com/repos/de-jaggl/sqlbuilder/releases/26302821","Warn: release artifact 2.6.9 does not have provenance: https://api.github.com/repos/de-jaggl/sqlbuilder/releases/25908230","Warn: release artifact 2.6.8 does not have provenance: https://api.github.com/repos/de-jaggl/sqlbuilder/releases/25851463"],"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#signed-releases"}},{"name":"Branch-Protection","score":-1,"reason":"internal error: error during branchesHandler.setup: internal error: githubv4.Query: Resource not accessible by integration","details":null,"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#branch-protection"}},{"name":"SAST","score":0,"reason":"SAST tool is not run on all commits -- score normalized to 0","details":["Warn: 0 commits out of 25 are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#sast"}},{"name":"Vulnerabilities","score":6,"reason":"4 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: GHSA-36p3-wjmg-h94x","Warn: Project is vulnerable to: GHSA-hh26-6xwr-ggv7","Warn: Project is vulnerable to: GHSA-6gf2-pvqw-37ph","Warn: Project is vulnerable to: GHSA-rfmp-97jj-h8m6"],"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#vulnerabilities"}}]},"last_synced_at":"2025-08-18T03:28:24.613Z","repository_id":57730608,"created_at":"2025-08-18T03:28:24.613Z","updated_at":"2025-08-18T03:28:24.613Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":28534159,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-01-18T00:39:45.795Z","status":"online","status_checked_at":"2026-01-18T02:00:07.578Z","response_time":98,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["java-library","mysql","sql","sql-builder","sql-statements","sqlbuilder","sybase","sybase-sql"],"created_at":"2026-01-18T09:31:36.261Z","updated_at":"2026-01-18T09:31:36.456Z","avatar_url":"https://github.com/de-jaggl.png","language":"Java","readme":"# SQLbuilder\n\n[![Maven Central](https://img.shields.io/maven-metadata/v/http/central.maven.org/maven2/de/jaggl/sqlbuilder/sqlbuilder-core/maven-metadata.xml.svg)](https://search.maven.org/#search%7Cgav%7C1%7Cg%3A%22de.jaggl.sqlbuilder%22%20AND%20a%3A%22sqlbuilder-core%22)\n[![Release](https://github.com/de-jaggl/sqlbuilder/workflows/release/badge.svg)](https://github.com/de-jaggl/sqlbuilder/actions)\n[![Nightly build](https://github.com/de-jaggl/sqlbuilder/workflows/nightly/badge.svg)](https://github.com/de-jaggl/sqlbuilder/actions)\n[![javadoc](https://javadoc.io/badge2/de.jaggl.sqlbuilder/sqlbuilder-core/javadoc.svg?)](https://javadoc.io/doc/de.jaggl.sqlbuilder/sqlbuilder-core)\n[![Quality Gate Status](https://sonarcloud.io/api/project_badges/measure?project=de-jaggl_sqlbuilder\u0026metric=alert_status)](https://sonarcloud.io/dashboard?id=de-jaggl_sqlbuilder)\n[![Maintainability Rating](https://sonarcloud.io/api/project_badges/measure?project=de-jaggl_sqlbuilder\u0026metric=sqale_rating)](https://sonarcloud.io/dashboard?id=de-jaggl_sqlbuilder)\n[![Reliability Rating](https://sonarcloud.io/api/project_badges/measure?project=de-jaggl_sqlbuilder\u0026metric=reliability_rating)](https://sonarcloud.io/dashboard?id=de-jaggl_sqlbuilder)\n[![Security Rating](https://sonarcloud.io/api/project_badges/measure?project=de-jaggl_sqlbuilder\u0026metric=security_rating)](https://sonarcloud.io/dashboard?id=de-jaggl_sqlbuilder)\n[![Lines of Code](https://sonarcloud.io/api/project_badges/measure?project=de-jaggl_sqlbuilder\u0026metric=ncloc)](https://sonarcloud.io/dashboard?id=de-jaggl_sqlbuilder)\n[![Coverage](https://sonarcloud.io/api/project_badges/measure?project=de-jaggl_sqlbuilder\u0026metric=coverage)](https://sonarcloud.io/dashboard?id=de-jaggl_sqlbuilder)\n[![Technical Debt](https://sonarcloud.io/api/project_badges/measure?project=de-jaggl_sqlbuilder\u0026metric=sqale_index)](https://sonarcloud.io/dashboard?id=de-jaggl_sqlbuilder)\n[![GitHub](https://img.shields.io/github/license/de-jaggl/sqlbuilder)](https://github.com/de-jaggl/sqlbuilder/blob/master/LICENSE)\n[![Gitter](https://badges.gitter.im/de-jaggl/community.svg)](https://gitter.im/de-jaggl/community?utm_source=badge\u0026utm_medium=badge\u0026utm_campaign=pr-badge)\n\nA Java-Library to build SQL-Statements\n\n### Dependency\n\n```xml\n\u003cdependency\u003e\n  \u003cgroupId\u003ede.jaggl.sqlbuilder\u003c/groupId\u003e\n  \u003cartifactId\u003esqlbuilder-core\u003c/artifactId\u003e\n  \u003cversion\u003e2.7.2\u003c/version\u003e\n\u003c/dependency\u003e\n```\n\n### Simple Example\n\n```java\nprivate static final Table PERSONS = Table.create(\"persons\");\nprivate static final VarCharColumn FORENAME = PERSONS.varCharColumn(\"forename\").size(50).build();\nprivate static final VarCharColumn LASTNAME = PERSONS.varCharColumn(\"lastname\").size(50).build();\n\npublic static final void main(String[] args)\n{\n  Queries.select()\n  \t.from(PERSONS)\n  \t.where(LASTNAME.eq(\"Doe\"))\n  \t.print();\n}\t\n```\nThis will output:\n```sql\nSELECT * FROM `persons` WHERE `persons`.`lastname` = 'Doe'\n```\nTo get the SQL-statement as a string, call `build()` instead of `print()`\n\n#### Some other examples:\n\nInsert:\n```java\nQueries.insertInto(PERSONS)\n\t.set(FORENAME, \"John\")\n\t.set(LASTNAME, \"Doe\")\n\t.print();\n```\n```sql\nINSERT INTO `persons` SET `persons`.`forename` = 'John', `persons`.`lastname` = 'Doe'\n```\n\nUpdate:\n```java\nQueries.update(PERSONS)\n\t.set(FORENAME, \"John\")\n\t.where(LASTNAME.eq(\"Doe\"))\n\t.print();\n```\n```sql\nUPDATE `persons` SET `persons`.`forename` = 'John', WHERE `persons`.`lastname` = 'Doe'\n```\n\nDelete:\n```java\nQueries.deleteFrom(PERSONS)\n\t.where(LASTNAME.eq(\"Doe\"))\n\t.print();\n```\n```sql\nDELETE FROM `persons` WHERE `persons`.`lastname` = 'Doe'\n```\n\nCreate table:\n```java\nQueries.createTable(PERSONS).println()\n```\n```sql\nCREATE TABLE `persons` (`forename` VARCHAR(50) DEFAULT NULL, `lastname` VARCHAR(50) DEFAULT NULL)\n```\n\n### Features\n\n- Build SQL-queries in different dialects, currently supported are:\n\t- MySQL\n\t- Sybase\n\t\n- Currently supported queries are:\n  - SELECT\n  - INSERT\n  - UPDATE\n  - DELETE\n  - CREATE TABLE\n  \n- Type-safe query-building. Currently supported column-datatypes are:\n\t- CHAR, VARCHAR, TEXT\n\t- INT, BIGINT, MEDIUMINT, SMALLINT, TINYINT\n\t- DOUBLE, FLOAT, DECIMAL\n\t- DATE, DATETIME\n\t\n- Supports SQL-Functions, currently supported are:\n\t- SUM\n\t- MIN\n\t- MAX\n\t- AVG\n\t- COUNT\n\t- NOW\n\t\n- Build queries with or without indentation\n\n### Choose dialect\n\nBy default the MySQL-dialect is chosen. To change the dialect, you can pass your wanted dialect to the `print()` or `build()`-method. The known dialects are collected in the Utility-Class `Dialects`. Simple example for choose the known Sybase-dialect:\n```java\nQueries.select()\n  .from(PERSONS)\n  .limit(100, 10)\n  .print(Dialects.SYBASE);\n```\nThis will output:\n```sql\nSELECT TOP 100 START AT 11 * FROM `persons`\n```\nIt is also possible to globally change the default-Dialect. To do so, set the system-property `sqlbuilder.defaultDialect` to the name of the Dialect you want.\n\n### Indentation\n\nJust add `Indentation.enabled()` to the `print()` or `build()`-method as follows:\n```java\nQueries.select()\n  .from(PERSONS)\n  .where(LASTNAME.eq(\"Doe\"))\n  .print(Indentation.enabled());\n```\nThis will output:\n```sql\nSELECT\n  *\nFROM\n  `persons`\nWHERE `persons`.`lastname` = 'Doe'\n```\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fde-jaggl%2Fsqlbuilder","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fde-jaggl%2Fsqlbuilder","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fde-jaggl%2Fsqlbuilder/lists"}