我是golang的新手,并且希望制作一个小型的待办事项Web应用程序,以完善我的围棋技能。我想知道什么是组织代码的好习惯。

现在,我为此项目定义了两个包:ticketserverticket与数据库有关,而server与http处理程序有关。

我的数据有两种类型:票证和待办事项。一张票证可以包含多个待办事项。它们在ticket包中定义。

type Ticket struct {
    Id          int64      `db:"id" json:"id"`
    Label       string     `db:"label" json:"label"`
    Description string     `db:"description" json:"description"`
    StartTime   time.Time  `db:"start_time" json:"start_time"`
    EndTime     *time.Time `db:"end_time" json:"end_time"`
    Priority    bool       `db:"priority" json:"priority"`
}
type Todo struct {
    Id       int64 `db:"id" json:"id"`
    Item     int64 `db:"item" json:"item"`
    TicketId int64 `db:"ticket_id" json:"ticket_id"`
    Active   bool  `db:"active" json:"active"`
}

ticket包中,我还定义了
type AppDB struct {
    db *sqlx.DB
}

这种围绕*sqlx.DB的换行使我可以将所有数据库访问功能放在ticket包中,例如,
func (adb *AppDB) MustInit()
func (adb *AppDB) AddTicket(i *Ticket) (int64, error)

server包中,我定义了
type Application struct {
    db ticket.AppDB
}

并且http处理函数定义为Application的方法,例如,
func (app *Application) CreateTicket(w http.ResponseWriter, req *http.Request)

main.go中,我注册了句柄函数。
func main() {
    app := server.NewApplication()

    fmt.Println("now listening...")
    router := mux.NewRouter()
    router.HandleFunc("/", app.Hello).Methods("GET")
    router.HandleFunc("/get", app.Get).Methods("GET")
    log.Fatal(http.ListenAndServe(":"+os.Getenv("PORT"), router))
}

我有以下问题:
  • 这是一个好的做法吗?如果没有,正确的方法是什么?
  • 在Donovan和Kernighan的Go编程书第194页中,他们给出了一个示例,其中直接将http处理程序定义为数据库的方法。那会是更好的设计吗?这是有道理的,因为我的server包仅适用于ticket中的数据类型。这也使代码编写起来更加简洁。另一方面,它将HTTP和数据库混合在一起,我不确定这是否是一件好事。
  • 如何处理数据库表创建?我是否应该创建另一个main.go,它仅创建数据库表并将其构建为可执行文件,这样我就可以在服务器上运行一次?
  • 最佳答案

  • 根据您的描述,我认为制作2个软件包是一个错误的决定。如果您要制作“小型Web应用程序”,那么拥有多个软件包将无非是要获得额外的复杂性。如果不确定,请始终选择较简单的解决方案。
  • 我不认为拥有2个软件包会更清洁或混合得更少。您可以将包中的东西放在几个不同的文件中,并用作不同结构的方法。
  • 这个怎么样?以幂等的方式定义数据库初始化(例如,如果不存在则创建SCHEMA,如果不存在则创建表),并在main.go刚开始的时候,每次在db.Ping()之后立即运行它。大多数情况下应为毫秒,并确保db始终具有您期望的结构。
  • 关于database - 休息一下api服务器设计的好习惯,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/41304058/

    10-11 00:10