1. 程式人生 > 實用技巧 >Beego generate自動生成程式碼 以及註解路由 @router

Beego generate自動生成程式碼 以及註解路由 @router

.使用bee generate 自動生成程式碼

bee generate scaffold user -fields="id:int64,name:string,gender:int,age:int" -driver=mysql -conn="root:123456@tcp(127.0.0.1:3306)/beego01"

說明:
scaffold :腳手架
user : 是表名
-fields : 是表字段名 欄位名冒號型別逗號
-driver: 驅動型別
-conn 連線資訊[需要確保資料庫beego01已經建立]
具體執行如下:

看下專案結構:
如下圖,發現MVC層的程式碼都自動生成了。

資料庫表也生成了


其中資料遷移程式碼如下:

往表user 插入資料:

三.修改配置,測試
1.修改router.go為

func init() {
    //beego.Router("/", &controllers.MainController{})
    beego.Include(&controllers.UserController{}) // 注意此行必須加
}

2.修改main.go為

func main() {
    _ = orm.RegisterDataBase("default", "mysql", "root:123456@/beego01?charset=utf8") // 注意此行必須加
    beego.Run()
}

專案根目錄bee run 編譯並啟動程式:
訪問http://localhost:8080/ , 返回如下資訊,表示成功了。

在這裡插入圖片描述
測試2,GetOne方法:
http://localhost:8080/3

測試3:刪除,請求方法型別必須是DELETE型別的,我們用Restlet Client工具模擬測試。
http://localhost:8080/2

bee run控制檯列印的日誌如下:很直觀。

看下資料庫是否刪除成功:發現id=2的資料已經被刪除了

好了,以上就是bee工具生成程式碼,並前後臺數據交單的小例子了。
當然你可以不執行上面的命令,單獨生成其中一個檔案,指定型別就行,比如model controller等
bee generate model goods
bee generate controller goods
細節就看官方文件:https://beego.me/docs/install/bee.md
再說下appcode,上面是根據命令生成檔案和資料庫,appcode就是根據資料庫生成檔案
例如:新建個表,

CREATE TABLE `news` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `title` varchar(255) NOT NULL COMMENT '新聞標題',
  `cid` int(11) DEFAULT NULL COMMENT '新聞分類',
  `created_time` date DEFAULT NULL COMMENT '新聞釋出時間',
  `content` text COMMENT '新聞內容',
  PRIMARY KEY (`id`),
  KEY `cid` (`cid`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='新聞表';

然後輸入如下命令:
bee generate appcode -tables=“news” -conn=“root:123456@tcp(127.0.0.1:3306)/beego01”
他就會生成一系列以上檔案。順便會修改routers/router.go 這個路由檔案【實踐後感覺這個命令修改的檔案有些問題】

bee generate controller news

在生成的程式碼 有一個 註釋// @router /:id [get] 非常 非常重要, 如果沒有它 beego.Include(&controllers.UserController{}) // 注意此行必須加 是無法自動識別的