wertet die rtcinfo files aus
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

117 lines
3.0 KiB

2 years ago
package database
import (
"database/sql"
"log"
2 years ago
"gitlab.dedyn.io/AUDIAG/rtcusertr/domain"
2 years ago
_ "github.com/go-sql-driver/mysql"
)
var (
dbConnection = "rtcusertrdbuser:hurtz3585@tcp(ubodroid-1:3306)/rtcusertrdb"
dbType = "mysql"
)
// Tool Funktionen
2 years ago
func CreateKnoten(knoten domain.KnotenE) (resKnoten domain.KnotenE, err error) {
2 years ago
conn, err := sql.Open(dbType, dbConnection)
if err != nil {
log.Println("Error while connecting DB: ", err)
}
log.Println("Verbindung hergestellt")
2 years ago
log.Println("Name = ", knoten.Fachbereich)
2 years ago
defer conn.Close()
2 years ago
res, err := conn.Exec("INSERT INTO knoten VALUES(?,?,?,?)", knoten.Id, knoten.Fachbereich, knoten.Anzahl, knoten.Tag)
2 years ago
if err != nil {
log.Println("Error while executing insert statement", err)
}
lastId, err := res.LastInsertId()
2 years ago
knoten.Id = uint(lastId)
resKnoten = knoten
2 years ago
2 years ago
return resKnoten, err
2 years ago
}
2 years ago
func DeleteKnoten(knotenId uint) (result, err error) {
2 years ago
conn, err := sql.Open(dbType, dbConnection)
if err != nil {
log.Println("Error while connecting DB: ", err)
}
log.Println("DB Verbindung hergestellt")
defer conn.Close()
2 years ago
_, err = conn.Exec("DELETE FROM knoten WHERE id = ?", knotenId)
2 years ago
if err != nil {
log.Fatal("Error while executing DELETE statement", err)
}
return result, err
}
2 years ago
func ShowKnoten() (knotenArray []domain.KnotenE, err error) {
2 years ago
conn, err := sql.Open(dbType, dbConnection)
if err != nil {
log.Println("Error while connecting DB: ", err)
}
log.Println("DB Verbindung hergestellt")
defer conn.Close()
2 years ago
results, err := conn.Query("SELECT * FROM knoten")
2 years ago
if err != nil {
log.Fatal("Error while executing SELECt statement", err)
}
2 years ago
var knoten domain.KnotenE
2 years ago
for results.Next() {
2 years ago
err = results.Scan(&knoten.Id, &knoten.Fachbereich, &knoten.Anzahl, &knoten.Tag)
2 years ago
if err != nil {
log.Fatal("Error: ", err)
}
2 years ago
knotenArray = append(knotenArray, knoten)
2 years ago
}
2 years ago
return knotenArray, err
2 years ago
}
2 years ago
func GetKnoten(id uint) (knoten domain.KnotenE, err error) {
2 years ago
conn, err := sql.Open(dbType, dbConnection)
if err != nil {
log.Println("Error while connecting DB: ", err)
}
log.Println("DB Verbindung hergestellt")
defer conn.Close()
2 years ago
results, err := conn.Query("SELECT * FROM knoten WHERE id=?", id)
2 years ago
if err != nil {
log.Fatal("Error while executing SELECt statement", err)
}
for results.Next() {
2 years ago
err = results.Scan(&knoten.Id, &knoten.Fachbereich, &knoten.Anzahl, &knoten.Tag)
2 years ago
if err != nil {
log.Fatal("Error: ", err)
}
}
2 years ago
return knoten, err
2 years ago
}
2 years ago
func UpdateKnoten(knoten domain.KnotenE) (resKnoten domain.KnotenE, err error) {
2 years ago
conn, err := sql.Open(dbType, dbConnection)
if err != nil {
log.Println("Error while connecting DB: ", err)
}
log.Println("Verbindung hergestellt")
2 years ago
log.Println("Name = ", knoten.Fachbereich)
2 years ago
defer conn.Close()
2 years ago
_, err = conn.Exec("UPDATE knoten SET fachbereich=?, anzahl=?, tag=? WHERE id=?", knoten.Fachbereich, knoten.Anzahl, knoten.Tag, knoten.Id)
2 years ago
if err != nil {
log.Println("Error while executing insert statement", err)
}
2 years ago
resKnoten = knoten
2 years ago
2 years ago
return resKnoten, err
2 years ago
}