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