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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM