日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無先后,達(dá)者為師

網(wǎng)站首頁 編程語言 正文

golang?beego框架路由ORM增刪改查完整案例_Golang

作者:Jeff的技術(shù)棧 ? 更新時間: 2022-06-16 編程語言

程序運行前加載

1.導(dǎo)包前面加下劃線,運行前加載

2.把要加載的寫在init函數(shù)里面

路由設(shè)置

路由的作用:根據(jù)不同的請求指定不同的控制器

路由函數(shù):

beego.Router("/path",&controller.MainController{})

函數(shù)參數(shù):

先分析一下Url地址由哪幾部分組成?

http://192.168.110.71:8080/index
http://地址:端口/資源路徑

第一個參數(shù):資源路徑,也就是 / 后面的內(nèi)容

第二個參數(shù):需要指定的控制器指針

了解上面的內(nèi)容之后我們來看幾個簡單的例子:

beego.Router("/", &controllers.MainController{}) 
beego.Router("/index", &controllers.IndexController{}) 
beego.Router("/login", &controllers.LoginController{})

高級路由設(shè)置

一般在開發(fā)過程中,我們基本不使用beego提供的默認(rèn)請求訪問方法,都是自定義相應(yīng)的方法。那我們來看一下如何來自定義請求方法。

自定義請求方法需要用到Router的第三個參數(shù)。這個參數(shù)是用來給不同的請求指定不同的方法。具體有如下幾種情況。

一個請求訪問一個方法(也是最常用的),請求和方法之間用 : 隔開,不同的請求用 ; 隔開:

beego.Router("/simple",&SimpleController{},"get:GetFunc;post:PostFunc")

可以多個請求,訪問一個方法 ,請求之間用 , 隔開,請求與方法之間用 : 隔開:

beego.Router("/api",&RestController{},"get,post:ApiFunc")

所有的請求訪問同一個方法,用 * 號代表所有的請求,和方法之間用 : 隔開:

beego.Router("/api/list",&RestController{},"*:ListFood")

如果同時存在 * 和對應(yīng)的 HTTP請求,那么優(yōu)先執(zhí)行 HTTP請求所對應(yīng)的方法,例如同時注冊了如下所示的路由:

beego.Router("/simple",&SimpleController{},"*:AllFunc;post:PostFunc")

那么當(dāng)遇到 Post 請求的時候,執(zhí)行 PostFunc 而不是 AllFunc。

如果用了自定義方法之后,默認(rèn)請求將不能訪問。

beego-ORM初始化

ORM-----對象關(guān)系映射

安裝ORM+導(dǎo)包

go get github.com/astaxie/beego/orm
import "github.com/astaxie/beego/orm"

定義結(jié)構(gòu)體

相當(dāng)于django中的model類

type User struct{ 
  Id int 
  Name string 
  PassWord string 
}

beego支持的數(shù)據(jù)庫

mysql,sqlite3,postgersql

驅(qū)動如下:

import (
    _ "github.com/go-sql-driver/mysql"
    _ "github.com/lib/pq"
    _ "github.com/mattn/go-sqlite3"
)

連接數(shù)據(jù)庫

用RegisterDataBase()函數(shù),第一個參數(shù)為數(shù)據(jù)庫別名,也可以理解為數(shù)據(jù)庫的key值,項目中必須有且只能有一個別名為 default 的連接,第二個參數(shù)是數(shù)據(jù)庫驅(qū)動,這里我們用的MySQL數(shù)據(jù)庫,所以以MySQL驅(qū)動為例,第三個參數(shù)是連接字符串,和傳統(tǒng)操作數(shù)據(jù)庫連接字符串一樣

格式為:用戶名:密碼@tcp(ip:port)/數(shù)據(jù)庫名稱?編碼方式

代碼如下:

orm.RegisterDataBase("default","mysql","root:@tcp(127.0.0.1:3306)/class1? charset=utf8")

注意:ORM只能操作表,不能操作數(shù)據(jù)庫,所以我們連接的數(shù)據(jù)庫要提前在MySQL終端創(chuàng)建好。

注冊數(shù)據(jù)庫表

用orm.RegisterModel()函數(shù),參數(shù)是結(jié)構(gòu)體對象,如果有多個表,可以用 , 隔開,多new幾個對象:

orm.RegisterModel(new(User))

生成表

用orm.RunSyncdb()函數(shù),這個函數(shù)有三個參數(shù),

第一個參數(shù)是數(shù)據(jù)庫的別名和連接數(shù)據(jù)庫的第一個參數(shù)相對應(yīng)。

第二個參數(shù)是是否強制更新,一般我們寫的都是false,如果寫true的話,每次項目編譯一次數(shù)據(jù)庫就會被清空一次,fasle的話會在數(shù)據(jù)庫發(fā)生重大改變(比如添加字段)的時候更新數(shù)據(jù)庫。

第三個參數(shù)是用來說,生成表過程是否可見,如果我們寫成課件,那么生成表的時候執(zhí)行的SQL語句就

會在終端看到。反之看不見。代碼如下:

orm.RunSyncdb("default",false,true)

完整案例

import "github.com/astaxie/beego/orm"
type User struct { 
	Id int 
	Name string 
	Passwd string 
}


func init(){
	//1.連接數(shù)據(jù)庫
 orm.RegisterDataBase("default","mysql","root:123456@tcp(127.0.0.1:3306)/test?charset=utf8")
	//2.注冊表
	orm.RegisterModel(new(User))
	// 3.生成表
	// 1.數(shù)據(jù)庫別名
	// 2.是否強制更新
	// 3.創(chuàng)建表過程是否可見 
	orm.RunSyncdb("default",false,true) 
}

因為這里我們把ORM初始化的代碼放到了 models包的init()函數(shù)里面,所以如果我們想讓他執(zhí)行的話就需要在main.go里面加入這么一句代碼:

import _ "classOne/models"

ORM增刪改查

在執(zhí)行ORM的操作之前需要先把ORM包導(dǎo)入,但是GoLand會自動幫我們導(dǎo)包,也可以手動導(dǎo)包

go get github.com/astaxie/beego/orm
import "github.com/astaxie/beego/orm"

插入

先獲取一個ORM對象,用orm.NewOrm()即可獲得

o := orm.NewOrm()
var user User  //定義一個要插入數(shù)據(jù)庫的結(jié)構(gòu)體對象
user.Name = "itcast" //給定義的對象賦值
user.Passwd = "heima"
//執(zhí)行插入操作,o.Insert()插入,參數(shù)是結(jié)構(gòu)體對象,返回值是插入的id和錯誤信息。
id, err := o.Insert(&user) 
if err == nil { 
  fmt.Println(id) 
}

注意:這里不用給Id賦值,因為建表的時候我們沒有指定主鍵,ORM默認(rèn)會以變量名為Id,類型為int的字段當(dāng)主鍵

查詢

查詢,用o.Read(),第一個參數(shù)是對象地址,第二個參數(shù)是指定查詢字段,返回值只有錯誤信息。

o := orm.NewOrm() //1.要先獲得一個ORM對象
var user User  //2.定義一個要獲取數(shù)據(jù)的結(jié)構(gòu)體對象
user.Name = "itcast" //3.給結(jié)構(gòu)體對象賦值,相當(dāng)于給查詢條件賦值
err := o.Read(&user,"Name") //4.查詢,用o.Read()
if err != nil{ 
  beego.Info("查詢數(shù)據(jù)錯誤",err) 
  return 
}

注意:如果查詢字段是查詢對象的主鍵的話,可以不用指定查詢字段

更新

執(zhí)行更新操作,用o.Update()函數(shù),參數(shù)是結(jié)構(gòu)體對象指針,返回值是更新的條目數(shù)和錯誤信息

o := orm.NewOrm() //1.要先獲得一個ORM對象
var user User  //2.定義一個要獲取數(shù)據(jù)的結(jié)構(gòu)體對象
user.Name = "itcast" //3.給結(jié)構(gòu)體對象賦值,相當(dāng)于給查詢條件賦值
err := o.Read(&user) //4.查詢更新的數(shù)據(jù)是否存在
if err != nil{ 
  beego.Info("查詢數(shù)據(jù)錯誤",err) 
  return 
}
user.Name = "jeff"  //5.如果查找到了要更新的對象,就給這個對象賦新值
count,err=o.Update(&user)  //6. 更新操作
if err != nil{ 
  beego.Info("更新數(shù)據(jù)錯誤",err) 
  return 
}

刪除

執(zhí)行刪除操作,用的方法是o.Delete(),參數(shù)是刪除的結(jié)構(gòu)體對象,返回值是刪除的條目數(shù)和錯誤信息

o := orm.NewOrm() //1.要先獲得一個ORM對象
var user User  //2.定義一個要獲取數(shù)據(jù)的結(jié)構(gòu)體對象
user.Id = 1   //3.給結(jié)構(gòu)體對象賦值,相當(dāng)于給查詢條件賦值
num, err := o.Delete(&User{Id: 1}) 
if err == nil { 
  fmt.Println(num) 
}

案例

注冊

在router.go文件的init()函數(shù)中加下面這行代碼: 路由文件

beego.Router("/register1", &controllers.MainController{})

Controllers/default.go業(yè)務(wù)邏輯中:

func (c *MainController) Get() {
	c.Data["data"] = "get請求"
	c.TplName = "register.html"
}
func (c *MainController) Post() {
	c.Data["name"] = "jeff"
	c.TplName = "register.html"
	userName := c.GetString("userName")
	passwd := c.GetString("passwd")
	beego.Info("用戶名",userName)
	beego.Info("密碼",passwd)
	if userName != "" || passwd != ""{
		c.Redirect("/login",400)
	}
	c.TplName = "register.html"
}

Views/register.html視圖文件中:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>注冊</title>
</head>
<body>
<div style="position:absolute;left:50%; top:50%;">
    <form action="/register1" method="post"> 用戶名:<input type="text" name="userName">
        <p></p> 密碼:<input type="password" name="passwd">
        <p></p> <input type="submit" value="注冊">
    </form>
</div>
</body>
</html>

案例2

路由:

beego.Router("/addAritcle", &controllers.MainController{},"post:AddAritcle;get:Index")

default業(yè)務(wù)邏輯:

func (c*MainController) AddAritcle() {
	c.Data["name"] = c.GetString("userName")
	c.Data["pwd"] = c.GetString("passwd")
	beego.Info("用戶名:",c.Data["name"])
	beego.Info("密碼",c.Data["pwd"])
	c.TplName = "success.html"
}
func (c*MainController) Index() {
	c.TplName = "addArticle.html"
}

view視圖

addArticle.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>成功</title>
</head>
<body>
<p style="font-size: 70px;color: brown">成功!!!</p>
<p>用戶名:{{.name}}</p>
<p>密碼:{{.pwd}}</p>
</body>
</html>

Success.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>成功</title>
</head>
<body>
<p style="font-size: 70px;color: brown">成功!!!</p>
<p>用戶名:{{.name}}</p>
<p>密碼:{{.pwd}}</p>
</body>
</html>

原文鏈接:https://www.cnblogs.com/guyouyin123/p/14041606.html

欄目分類
最近更新