Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Shelnutt2/db2struct
Converts a mysql table into a golang struct
https://github.com/Shelnutt2/db2struct
hacktoberfest2020
Last synced: 3 months ago
JSON representation
Converts a mysql table into a golang struct
- Host: GitHub
- URL: https://github.com/Shelnutt2/db2struct
- Owner: Shelnutt2
- License: gpl-3.0
- Created: 2016-06-02T11:07:24.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2023-03-06T23:47:57.000Z (almost 2 years ago)
- Last Synced: 2024-10-15T22:08:07.465Z (3 months ago)
- Topics: hacktoberfest2020
- Language: Go
- Homepage:
- Size: 1.1 MB
- Stars: 549
- Watchers: 19
- Forks: 125
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-modernization - db2struct - db2struct package produces a usable golang struct from a given database table for use in a `.go` file. (Database / Datbase to Struct)
- go-awesome - db2struct - Generate structure according to table structure (Open source library / Code Generation)
README
# db2struct [![Build Status](https://travis-ci.org/Shelnutt2/db2struct.svg?branch=master)](https://travis-ci.org/Shelnutt2/db2struct) [![Coverage Status](https://coveralls.io/repos/github/Shelnutt2/db2struct/badge.svg?branch=1-add-coveralls-support)](https://coveralls.io/github/Shelnutt2/db2struct?branch=1-add-coveralls-support) [![GoDoc](https://godoc.org/github.com/Shelnutt2/db2struct?status.svg)](https://godoc.org/github.com/Shelnutt2/db2struct)
The db2struct package produces a usable golang struct from a given database table for use in a .go file.
By reading details from the database about the column structure, db2struct generates a go compatible struct type
with the required column names, data types, and annotations.Generated datatypes include support for nullable columns [sql.NullX types](https://golang.org/pkg/database/sql/#NullBool) or [guregu null.X types](https://github.com/guregu/null)
and the expected basic built in go types.Db2Struct is based/inspired by the work of ChimeraCoder's gojson package
[gojson](https://github.com/ChimeraCoder/gojson)## Usage
```BASH
go get github.com/Shelnutt2/db2struct/cmd/db2struct
db2struct --host localhost -d test -t test_table --package myGoPackage --struct testTable -p --user testUser
```## Example
MySQL table named users with four columns: id (int), user_name (varchar(255)), number_of_logins (int(11),nullable), and LAST_NAME (varchar(255), nullable)
Example below uses guregu's null package, but without the option it procuded the sql.NullInt64 and so on.
```BASH
db2struct --host localhost -d example.com -t users --package example --struct user -p --user exampleUser --guregu --gorm
```Output:
```GOLANGpackage example
type User struct {
ID int `gorm:"column:id"`
UserName string `gorm:"column:user_name"`
NumberOfLogins null.Int `gorm:"column:number_of_logins"`
LastName null.String `gorm:"column:LAST_NAME"`
}
```## Supported Databases
Currently Supported
- MariaDB
- MySQLPlanned Support
- PostgreSQL
- Oracle
- Microsoft SQL Server### MariaDB/MySQL
Structures are created by querying the INFORMATION_SCHEMA.Columns table and then formatting the types, column names,
and metadata to create a usable go compatible struct type.NOTE: If you wish to use a unix socket instead of a TCP socket,
specify the hostname as `unix:` then the path to the named socket.
For example:```BASH
--host unix:/tmp/mysql.sock
```#### Supported Datatypes
Currently only a limited number of MariaDB/MySQL datatypes are supported. Initial support includes:
- tinyint (sql.NullInt64 or null.Int)
- int (sql.NullInt64 or null.Int)
- smallint (sql.NullInt64 or null.Int)
- mediumint (sql.NullInt64 or null.Int)
- bigint (sql.NullInt64 or null.Int)
- decimal (sql.NullFloat64 or null.Float)
- float (sql.NullFloat64 or null.Float)
- double (sql.NullFloat64 or null.Float)
- datetime (null.Time)
- time (null.Time)
- date (null.Time)
- timestamp (null.Time)
- var (sql.String or null.String)
- enum (sql.String or null.String)
- varchar (sql.String or null.String)
- longtext (sql.String or null.String)
- mediumtext (sql.String or null.String)
- text (sql.String or null.String)
- tinytext (sql.String or null.String)
- binary
- blob
- longblob
- mediumblob
- varbinary
- json