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{}) // 注意此行必須加 是無法自動識別的