diff options
| author | Physick <96335032+DegustatorPonos@users.noreply.github.com> | 2025-11-29 20:18:11 +0500 |
|---|---|---|
| committer | Physick <96335032+DegustatorPonos@users.noreply.github.com> | 2025-11-29 20:18:11 +0500 |
| commit | e07dca81d05f304865a59c8afee98a3cde8bce8c (patch) | |
| tree | 2dd01bbc5fd20b6ae024f0c18eb8946887ae9339 /DAL/DB/CRUD.go | |
Project init
Diffstat (limited to 'DAL/DB/CRUD.go')
| -rw-r--r-- | DAL/DB/CRUD.go | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/DAL/DB/CRUD.go b/DAL/DB/CRUD.go new file mode 100644 index 0000000..a3b4a24 --- /dev/null +++ b/DAL/DB/CRUD.go @@ -0,0 +1,36 @@ +package db + +import ( + "reflect" + "strings" +) + +type DataTable[T any] struct { + TableName string +} + +// Forms a query to get all the fields from database +func (self *DataTable[T]) formSelectRequest() string { + var sb = strings.Builder{} + sb.WriteString("SELECT (") + var fields = self.getFields() + for i, v := range fields { + if i != 0 { + sb.WriteString(", ") + } + sb.WriteString(v) + } + sb.WriteString(") FROM ") + sb.WriteString(self.TableName) + sb.WriteString(";") + return sb.String() +} + +func (self *DataTable[T]) getFields() []string { + var zero T + var outp = make([]string, 0) + for _, f := range reflect.VisibleFields(reflect.TypeOf(zero)) { + outp = append(outp, f.Name) + } + return outp +} |
