Beego ———— orm实现获取数据并写入到数据库中

 新建一个controller文件,当用户访问http://localhost:8080/registe这个地址时 提交get,get方法返回一个页面让用户填写数据并post提交,post获得数据,并解析,我写了两种方式,一个是,根据关键词,并初始化一个新的结构体,让其插入到数据库中,

package controllers

import (
	"github.com/astaxie/beego"
	"fmt"
	_ "demo2/models"
	"demo2/models"
	"github.com/astaxie/beego/orm"
)

type Demo4Controlle struct {
	beego.Controller
}

func (this *Demo4Controlle) Get() {

	this.TplName = "register.html"
}


func (this *Demo4Controlle)Post(){

	user := models.User{}

	err := this.ParseForm(&user)
	if err!= nil {
		this.Ctx.WriteString("获取表格失败!"+fmt.Sprint(err))
	}else {
		orm:=orm.NewOrm()

		_, e := orm.Insert(&user)
		if e != nil {

			this.Ctx.WriteString("插入失败!" + fmt.Sprint(e))
		} else {

			this.Ctx.WriteString("插入成功!")
		}


	}

}




func (this *Demo4Controlle) Post1() {

	name := this.GetString("name")
	nickname := this.GetString("nickname")
	password := this.GetString("password")
	age, e := this.GetInt("age")
	if e != nil {
		this.Ctx.WriteString("年龄获取失败!" + fmt.Sprint(e))
	}
	sex, e1 := this.GetBool("sex")

	if e1 != nil {
		this.Ctx.WriteString("获取性别失败!")
	}
	var user = models.User{Name:name, NickName:nickname, Password:password, Age:age, Sex:sex}
	orm := orm.NewOrm()

	_, i2 := orm.Insert(&user)
	if i2 != nil {

		this.Ctx.WriteString("插入失败!" + fmt.Sprint(i2))
	} else {

		this.Ctx.WriteString("插入成功!")
	}

}

 注册路由

	//注册
	beego.Router("/registe",&controllers.Demo4Controlle{})

用户访问时,获得这个页面,这个页面默认存放在view模块下

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>register</title>
</head>
<body>

<form action="registe" method="post">
<form>
    <table>
        <thead>注册</thead>
        <tbody>
        <tr>
            <td>
            <label for="name">姓名:</label>
            <input type="text" name="name" id="name">
            </td>
        </tr>
        <tr>
            <td>
                <label for ="nickname">昵称:</label>
                <input type="text" name = "nickname" id="nickname">
            </td>
        </tr>
        <tr>
            <td>
                <label for = "password">密码:</label>
                <input type="password" name = "password" id="password">
            </td>
        </tr>
        <tr>
            <td>
                <label for = "age">年龄:</label>
                <input type="text" name = "age" id="age">
            </td>
        </tr>


        <tr>
            <td>
                <label for = "man">男:</label>
                <input type="radio" id="man" value="true" name="sex" >
                <label for = "women">女:</label>
                <input type="radio" id="women" name ="sex" value="false" >
            </td>
        </tr>
        <tr>
            <td>
               <input type="submit" value="提交">
                <input type="reset" value="重置">
            </td>
        </tr>
        </tbody>
    </table>
</form>
</form>

</body>
</html>

 在model中新建一个文件,`form:"name"`这个是表明表格中的关键字是name对应着结构体中Name,也可以在html文件中将关键字定义为Name,这样就不用声明了。

package models

import (
	"github.com/astaxie/beego"
	"github.com/astaxie/beego/orm"
	_"github.com/go-sql-driver/mysql"
)

type User struct {
	Id int
	Name     string `form:"name"`
	NickName string`form:"nickname"`
	Password string`form:"password"`
	Age      int`form:"age"`
	Sex      bool`form:"sex"`
}

func init(){

	db_name:=beego.AppConfig.String("db_name")
	db_user := beego.AppConfig.String("db_user")
	db_password := beego.AppConfig.String("db_password")
	db_host := beego.AppConfig.String("db_host")
	db_port := beego.AppConfig.String("db_port")

//root:123456@tcp(localhost:3306)/user?charset=utf8
	url:=db_user+":"+db_password+"@tcp("+db_host+":"+db_port+")/"+db_name+"?charset=utf8"

	orm.RegisterDataBase("default","mysql",url,30)

	orm.RegisterModel(new(User))

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


}

 

 

 

 

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Spring Boot,可以通过使用线程池来提高并发处理能力,而MyBatis-Plus则是一个优秀的ORM框架,可以简化数据库操作。下面是一个实现大数据量写入MySQL数据库的示例代码: 首先,在Spring Boot的配置文件配置线程池: ```properties # 线程池配置 spring.task.execution.pool.core-size=10 spring.task.execution.pool.max-size=20 spring.task.execution.pool.queue-capacity=1000 ``` 然后,创建一个数据写入服务类,使用@Async注解将其方法异步执行,并使用MyBatis-Plus的BatchExecutor来批量插入数据: ```java @Service public class DataWriteService { @Autowired private MybatisSqlSessionFactoryBean sqlSessionFactory; @Async public void writeData(List<Data> dataList) { try(SqlSession sqlSession = sqlSessionFactory.getObject().openSession(ExecutorType.BATCH)) { DataMapper dataMapper = sqlSession.getMapper(DataMapper.class); for(Data data : dataList) { dataMapper.insert(data); } sqlSession.commit(); } } } ``` 最后,在需要写入数据的地方调用数据写入服务类的方法即可: ```java @Service public class DataService { @Autowired private DataWriteService dataWriteService; public void processData(List<Data> dataList) { // 分批处理数据 int batchSize = 1000; int size = dataList.size(); for(int i = 0; i < size; i += batchSize) { int endIndex = Math.min(i + batchSize, size); List<Data> subList = dataList.subList(i, endIndex); dataWriteService.writeData(subList); } } } ``` 这样,就可以使用线程池和MyBatis-Plus来实现大数据量写入MySQL数据库了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值