.使用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{}) // 注意此行必须加 是无法自动识别的