From 6c36822ecca0a49c4172e4e8ba4ca35feef488f4 Mon Sep 17 00:00:00 2001 From: Reinaldy Rafli Date: Thu, 24 Jun 2021 15:15:36 +0700 Subject: [PATCH] feat(error): error on empty table name; error on missing primary and unique key in columns; --- create.go | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/create.go b/create.go index ef8a069..3679731 100644 --- a/create.go +++ b/create.go @@ -55,7 +55,7 @@ func (b CreateBuilder) ToSql() (string, []interface{}, error) { } func (d *createData) ToSql() (sqlStr string, args []interface{}, err error) { - if len(d.TableName) == 0 { + if len(d.TableName) == 0 || d.TableName == "" { err = errors.New("create statements must specify a table") return } @@ -85,12 +85,20 @@ func (d *createData) ToSql() (sqlStr string, args []interface{}, err error) { sql.WriteString(strings.Join(columnTypes, ", ")) sql.WriteString(");") - if d.Primary != "" && util.IsIn(d.Columns, d.Primary) { + if d.Primary != "" { + if !util.IsIn(d.Columns, d.Primary) { + err = errors.New("supplied primary column name doesn't exists on columns") + return + } sql.WriteString(" ") sql.WriteString("ALTER TABLE `" + d.TableName + "` ADD PRIMARY KEY (`" + d.Primary + "`);") } - if d.Unique != "" && util.IsIn(d.Columns, d.Unique) { + if d.Unique != "" { + if !util.IsIn(d.Columns, d.Unique) { + err = errors.New("supplied unique column name doesn't exists on columns") + return + } sql.WriteString(" ") sql.WriteString("ALTER TABLE `" + d.TableName + "` ADD UNIQUE (`" + d.Unique + "`);") }