golang利用beego框架orm操作mysql
GO引入orm框架操作mysql
在beego框架中引入orm操作mysql需要进行的步骤:
第一步:导入orm框架依赖,导入mysql数据库的驱动依赖
import (
"github.com/astaxie/beego/orm" //导入orm框架
_ "github.com/go-sql-driver/mysql" //导入数据库驱动
)
第二步:进行模型结构定义
//例如定义user表模型结构
type TestUser struct {
Id int `orm:"pk;auto;column(user_id)"` //表示设置为主键并且自增,列名为user_id
Name string `orm:"size(100)"column(user_name)`
Sex int `orm:"size(2);column(gender)"`
CreateDate time.Time `orm:"type(date);column(create_date)"`
Age int `orm:size(10);column(age)`
}
//注意:以上的字段名必须大写,否则无法识别
在进行模型结构定义需要注意的是(模型结构定义也就是表字段定义,beego中的orm框架会自动给你生成模型定义对应的表):
关于表名:默认是生成以结构名小写并且加上s结尾的表名,也可以自行设置表名
func (u *模型结构名) TableName() string {
return "你设置的表名"
}
关于索引定义:可以为单个字段或多个字段添加索引
// 多字段索引
func (u *模型结构名) TableIndex() [][]string {
return [][]string{
[]string{"字段1", "字段2"},
}
}
// 多字段唯一键
func (u *模型结构名) TableUnique() [][]string {
return [][]string{
[]string{"字段1", "字段2"},
}
}
写法都是固定了,只要按照这样的方式写就可以了
关于自定义引擎:对mysql可以支持自定义引擎
// 设置引擎为 INNODB
func (u *模型结构名) TableEngine() string {
return "INNODB"
}
关于字段属性的设置:例如字段大小,字段的为空不为空等设置
多个设置间使用 ;
分隔,设置的值如果是多个,使用 ,
分隔。
在设置属性时都是以orm:"你的设置"
开头
设置int类型通常为id字段自增并且为主键:orm:"pk;auto"
为空设置:数据库表默认为 NOT NULL
,设置 null 代表 ALLOW NULL
Name string orm:"null"
表示name字段可以为空
为单个字段添加索引或者唯一索引:Name strig orm:"index"
或者`Name string orm:"unique"
为字段设置对应的列名: Name string orm:"column(user_name)"
设置字段的大写设置 size 以后,db type 将使用 varchar(size): Name string orm:"size(10)"
为字段设置浮点数精度:Money float64 orm:"digits(12);decimals(4)"
结果显示9999.9999
时间类型的设置
设置为 date 时,time.Time 字段的对应 db 类型使用 date
Created time.Time `orm:"auto_now_add;type(date)"`
设置为 datetime 时,time.Time 字段的对应 db 类型使用 datetime
Created time.Time `orm:"auto_now_add;type(datetime)"`
设置为字段添加注释:注释中禁止包含引号
Status int orm:"default(1)" description:"这是状态字段"
第三步:进行初始化操作,主要进行建立数据库连接,以及注册模型结构,建表等操作。
func init() {
//注册数据库,一共有五个参数,后面连个用于连接池操作
_ = orm.RegisterDataBase("default", "mysql",
"root:123456@tcp(172.16.163.128:3307)/goodsinfo?charset=utf8")
//进行注册模型结构,可以有多个,用逗号分隔
orm.RegisterModel(new(Stu))
//创建表,默认为default,只建立一次,后面再执行这个会忽略
_ = orm.RunSyncdb("default", false, true)
}
注:以上没有引入关联关系操作
第四步:编写sql语句进行操作mysql数据库
//查询所有学生信息
func SelectAll() []orm.Params {
o := orm.NewOrm()
var maps []orm.Params
_, _ = o.Raw("select * from stu_stu").Values(&maps)
return maps
}
//根据id查询学生信息
func SelectById(id int) Stu {
o:=orm.NewOrm()
_ = o.Raw("select * from stu_stu where id=?", id).QueryRow(&stu)
return stu
}
//根据id删除用户
func Deletebyid(id int) {
o := orm.NewOrm()
_ = o.Raw("delete from stu_stu where id = ?", id).QueryRow(&stu)
}
//根据id更新信息
func Updatebyid(id int,name string) {
o:=orm.NewOrm()
_ = o.Raw("update stu_stu set name=? where id=?", name, id).QueryRow(&stu)
}
//插入数据
func InsertData(id int,name string) {
o:=orm.NewOrm()
_ = o.Raw("insert into stu_stu values(?,?)", id, name).QueryRow(&stu)
}
//根据name进行模糊查询
func SelectUnClear(name string) []orm.Params {
o := orm.NewOrm()
var maps []orm.Params
_, _ = o.Raw("select * from stu_stu where name like ?","%"+name+"%").Values(&maps)
return maps
}
控制器编写并且返回json数据
package controllers
import (
"github.com/astaxie/beego"
"github.com/astaxie/beego/orm"
"goorm/models"
)
type SelectAll struct {
beego.Controller
}
//全局变量
var stu models.Stu
//查询所有信息
func (c *SelectAll) Get() {
var maps []orm.Params
maps = models.SelectAll()
c.Data["json"]=maps
c.ServeJSON()
}
type SelectbyId struct {
beego.Controller
}
//根据id查询用户
func (c *SelectbyId) Get() {
id, _ := c.GetInt(":id")
stu = models.SelectById(id)
c.Data["json"]=stu
c.ServeJSON()
}
//根据id删除用户
type DeletebyId struct {
beego.Controller
}
func (c *DeletebyId) Get() {
id, _ := c.GetInt(":id")
models.Deletebyid(id)
str:=models.SelectAll()
c.Data["json"]=str
c.ServeJSON()
}
//根据id更新信息
type Updatebyid struct {
beego.Controller
}
func (c *Updatebyid) Get() {
id,_:=c.GetInt(":id")
name:=c.GetString(":name")
models.Updatebyid(id,name)
str:=models.SelectAll()
c.Data["json"]=str
c.ServeJSON()
}
//插入数据
type InsertData struct {
beego.Controller
}
func (c *InsertData) Get() {
id, _ :=c.GetInt(":id")
name:=c.GetString(":name")
models.InsertData(id,name)
str:=models.SelectAll()
c.Data["json"]=str
c.ServeJSON()
}
//模糊查询
type SelectUnClear struct {
beego.Controller
}
func (c *SelectUnClear) Get() {
name:=c.GetString(":name")
var maps []orm.Params
maps = models.SelectUnClear(name)
c.Data["json"]=maps
c.ServeJSON()
}
以上就是beego引入orm框架操作mysql数据库的简单练习
数据多模式输出 ---json,xml,jsonp
beego 当初设计的时候就考虑了 API 功能的设计,而我们在设计 API 的时候经常是输出 JSON 或者 XML 数据,那么 beego 提供了这样的方式直接输出:
注意 struct 属性应该 为 exported Identifier 也就是首字母应该大写
JSON 数据直接输出:
func (this *AddController) Get() {
mystruct := { ... }
this.Data["json"] = &mystruct
this.ServeJSON()
}
调用 ServeJSON 之后,会设置
content-type
为application/json
,然后同时把数据进行 JSON 序列化输出。XML 数据直接输出:
func (this *AddController) Get() {
mystruct := { ... }
this.Data["xml"]=&mystruct
this.ServeXML()
}
调用 ServeXML 之后,会设置
content-type
为application/xml
,同时数据会进行 XML 序列化输出。jsonp 调用
func (this *AddController) Get() {
mystruct := { ... }
this.Data["jsonp"] = &mystruct
this.ServeJSONP()
}
调用 ServeJSONP 之后,会设置
content-type
为application/javascript
,然后同时把数据进行 JSON 序列化,然后根据请求的 callback 参数设置 jsonp 输出。
开发模式下序列化后输出的是格式化易阅读的 JSON 或 XML 字符串;在生产模式下序列化后输出的是压缩的字符串。
golang页面模板tpl从列表中循环取值
{{range .mydata}}
<option value="{{.id}},{{.name}}">[ {{.id}},{{.name}} ]</option>
{{end}}
如果是返回的是对象列表:例如:[{...}{....}{....}],现在我想取里面的第一个{}内容,使用{{index .Keys 1}}即可。
如果是想取结构体里面某一个字段的值则使用:{{(index .Keys 1).propert_name}}
golang利用beego框架orm操作mysql的更多相关文章
- golang的beego框架开发时出现的问题纪录
golang的beego框架开发时出现的问题纪录1.数据库并发时问题:[ORM]2017/02/20 23:44:05 -[Queries/default] - [FAIL / db.Query / ...
- .net core使用orm操作mysql数据库
Mysql数据库由于其体积小.速度快.总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库.MySQL是一个多用户.多线程的关系型数据库管理系 ...
- Go语言使用Beego的ORM插入Mysql后,时区不一致的解决方案
一.解决方案: 方案一: orm.Debug = false orm.DefaultTimeLoc = time.UTC orm.RegisterDriver("mysql", o ...
- beego orm操作mysql数据库
慢慢弄起来~~ 按官方操作文档试一下. 那个err重复和user编号问题,以后再弄.. package main import ( "fmt" "github.com/a ...
- Flask学习笔记:数据库ORM操作MySQL+pymysql/mysql-python+SQLAlchemy/Flask-SQLAlchemy
Python中使用sqlalchemy插件可以实现ORM(Object Relationship Mapping,模型关系映射)框架,而Flask中的flask-sqlalchemy其实就是在sqla ...
- sqlalchemy orm 操作 MySQL
一.ORM介绍 orm英文全称object relational mapping,是对象映射关系程序,简单来说类似python这种面向对象的程序来说一切皆对象,但是我们使用的数据库却都是关系型的,为了 ...
- PHP ORM操作MySQL数据库
ORM----Oriented Relationship Mapper,即用面向对象的方式来操作数据库.归根结底,还是对于SQL语句的封装. 首先,我们的数据库有如下一张表: 我们希望能够对这张表,利 ...
- ORM操作mysql
创建表和添加数据 import sqlalchemyfrom sqlalchemy import create_enginefrom sqlalchemy.ext.declarative import ...
- 一种利用ADO连接池操作MySQL的解决方案(VC++)
VC++连接MySQL数据库 常用的方式有三种:ADO.mysql++,mysql API ; 本文只讲述ADO的连接方式. 为什么要使用连接池? 对于简单的数据库应用,完全可以先创建一个常连接(此连 ...
随机推荐
- MyBatis 整合 Druid
pom.xml 依赖 <?xml version="1.0" encoding="UTF-8"?> <project xmlns=" ...
- Vue-2:官方教程学习
1,先把下面这些内容都按照官方教程敲一遍,打好基础,类似于“前戏”,其作用我想爸爸就不必多说了吧(づ。◕‿‿◕。)づ. https://cn.vuejs.org/v2/guide/ 同时可以配合配套视 ...
- yum源安装mysql数据库 添加密码
学习mysql数据库时,安装的问题一直很烦恼,linux的不同版本的安装方式都可能不同,这里是我学习时的一些总结.也是刚刚开始学习,大佬勿喷,谢谢啦!!! 1.查看是否已经安装 2.如果没安装 yum ...
- spring mvc 异步 DeferredResult
当一个请求到达API接口,如果该API接口的return返回值是DeferredResult,在没有超时或者DeferredResult对象设置setResult时,接口不会返回,但是Servlet容 ...
- 【JulyEdu-Python基础】第 6 课:高级面向对象
使用@property添加属性和自定义属性 __slots__和property 方法和属性的动态绑定 使用__slots__限定class实例能添加的属性 __slots__仅对当前类实例起作用,对 ...
- 机器学习笔记:支持向量机(svm)
支持向量机(svm)英文为Support Vector Machines 第一次接触支持向量机是2017年在一个在线解密游戏"哈密顿行动"中的一个关卡的二分类问题,用到了台湾教授写 ...
- python基础之字典dict
不可变数据类型:tuple.bool.int.str --可哈希类型可变数据类型:list.dict.set --不可哈希类型dict-key 必须是不可变数据类型,可哈希dict-value 任意数 ...
- windows 环境安装K8s
文档地址: https://yq.aliyun.com/articles/508460?spm=a2c4e.11153940.blogcont221687.18.7dd57733hFolMo Dock ...
- 那些年,我们见过的 Java 服务端乱象
导读 查尔斯·狄更斯在<双城记>中写道:“这是一个最好的时代,也是一个最坏的时代.” 移动互联网的快速发展,出现了许多新机遇,很多创业者伺机而动:随着行业竞争加剧,互联网红利逐渐消失,很多 ...
- 以石子合并为例的区间DP
区间DP,是一类具有较为固定解法的DP,一般的思路都是: first.初始化区间长度为1的情况(一般区间长度为1的较易于初始化) second. for(枚举区间长度2~n){ for(枚举左端点){ ...