Skip to content

Commit 8a58933

Browse files
fix(codegen/golang): BREAKING: Use int16 for MySQL SMALLINT and YEAR (#3106)
Resolves #3088
1 parent 8d68872 commit 8a58933

File tree

4 files changed

+17
-8
lines changed

4 files changed

+17
-8
lines changed

internal/codegen/golang/mysql_type.go

Lines changed: 10 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -38,7 +38,16 @@ func mysqlType(req *plugin.GenerateRequest, options *opts.Options, col *plugin.C
3838
return "sql.NullInt32"
3939
}
4040

41-
case "int", "integer", "smallint", "mediumint", "year":
41+
case "smallint", "year":
42+
if notNull {
43+
if unsigned {
44+
return "uint16"
45+
}
46+
return "int16"
47+
}
48+
return "sql.NullInt16"
49+
50+
case "int", "integer", "mediumint":
4251
if notNull {
4352
if unsigned {
4453
return "uint32"

internal/endtoend/testdata/datatype/mysql/go/models.go

Lines changed: 3 additions & 3 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

internal/endtoend/testdata/vet_explain/mysql/db/models.go

Lines changed: 2 additions & 2 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

internal/endtoend/testdata/vet_explain/mysql/db/query.sql.go

Lines changed: 2 additions & 2 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

0 commit comments

Comments
 (0)