{"id":16674142,"url":"https://github.com/byrnedo/partu","last_synced_at":"2026-05-06T13:08:30.442Z","repository":{"id":57535120,"uuid":"283210076","full_name":"byrnedo/partu","owner":"byrnedo","description":"Go library to help with mundane sql fooery: generate insert, upsert, update and select statements","archived":false,"fork":false,"pushed_at":"2020-08-03T11:27:19.000Z","size":53,"stargazers_count":1,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-01-19T19:49:11.128Z","etag":null,"topics":["go","mysql","postgresql","sql"],"latest_commit_sha":null,"homepage":"","language":"Go","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/byrnedo.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":"2020-07-28T12:46:21.000Z","updated_at":"2021-03-02T07:09:14.000Z","dependencies_parsed_at":"2022-09-26T18:21:49.845Z","dependency_job_id":null,"html_url":"https://github.com/byrnedo/partu","commit_stats":null,"previous_names":["byrnedo/partoo"],"tags_count":16,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/byrnedo%2Fpartu","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/byrnedo%2Fpartu/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/byrnedo%2Fpartu/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/byrnedo%2Fpartu/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/byrnedo","download_url":"https://codeload.github.com/byrnedo/partu/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":243326822,"owners_count":20273548,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","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":["go","mysql","postgresql","sql"],"created_at":"2024-10-12T12:29:26.220Z","updated_at":"2025-12-28T13:23:01.815Z","avatar_url":"https://github.com/byrnedo.png","language":"Go","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Partu\n\nOpinionated and simple query builder for select, insert and update commands.\nJust generates sql.\n\nSupports Mysql and Postgres\n\n```go\nm := \u0026MyModel{}\np := partu.New(partu.Postgres)\nsqlStr, args := p.Insert(m)\n// Return corresponds to:\n//\n//  \"INSERT INTO some_table (id, foo)\n//   VALUES ($1,$2)\",\n//  []interface{}{\u0026m.ID, \u0026m.Foo}\n\n// Or if AutoID isn't fulfilled\n//\n// \"INSERT INTO some_table (foo)\n//  VALUES ($1)\",\n// []interface{}{\u0026m.Foo}\n```\n\n\nImplement the `Table` interface on your model type\n```go\npackage mine\nimport (\n    \"github.com/byrnedo/partu\"\n)\n\n// Note you must have the tag right now, there is no default, but you can override it with `SetTag`\ntype MyModel struct {\n    ID  string `sql:\"id\"`\n    Foo string `sql:\"foo\"`\n}\n\nfunc (t MyModel) TableName() string {\n    return \"some_table\"\n}\n\nfunc (t *MyModel) Columns() partu.Cols {\n    return partu.Cols{\n        \u0026t.ID,\n        \u0026t.Foo,\n    }\n}\n\n// OPTIONAL: if you want to manually create your ids, return false\nfunc (t *MyModel) AutoID() bool {\n    return false\n}\n```\n\n\n\n### Assumptions\n\n- Your ID column is the first column in the Columns list\n- You always update every field except the ID \n- You always select every field\n\n\n### Available SQL generating methods:\n\n- `Select(t Table)`     \n    - `SELECT [cols]`\n- `SelectFrom(t Table)`\n    - `SELECT [cols] FROM [table]`\n- `SelectOne(t Table)`\n    - `SELECT [cols] FROM [table] WHERE [id] = [placeholder]`\n- `Insert(t Table)`\n    - `INSERT INTO [table] ([cols]) VALUES ([placeholders])`\n- `Update(t Table)`\n    - `UPDATE [table] SET [cols = placeholders]`\n- `UpdateOne(t Table)`\n    - `UPDATE [table] SET [cols = placeholders] WHERE [id] = [placeholder]`\n- `UpsertOne(t Table)`\n    - `INSERT INTO [table] ([cols]) VALUES ([placeholders]) ON CONFLICT ([id]) UPDATE SET [cols = placeholders]`\n   \n### Helper functions\n\n- `AssignmentString(fields namedFields, startIndex int) string`\n    - eg. if startIndex = 1, returns `\"[col1] = $1, [col2] = $2, ...\"`\n\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fbyrnedo%2Fpartu","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fbyrnedo%2Fpartu","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fbyrnedo%2Fpartu/lists"}