IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> Golang操作MySQL(一)——用gorm实现curd -> 正文阅读

[大数据]Golang操作MySQL(一)——用gorm实现curd

参考——李文周的博客

什么是GORM

GORM是一个go语言开发的ORM框架,ORM全称是Object-Relationship-Mapping,像Java中经常用到的MyBatis就是一个ORM框架,而GORM也是一样,大大降低了对开发人员的sql语句能力,开发人员只需要调用框架中的api即可,剩下的由GORM框架将代码转换成SQL语句后,对数据库进行操作

优点:对开发人员友好,大大提高了开发效率
缺点:
1.牺牲了程序性能
2.弱化了开发人员的sql能力的能力

如何在Goland中使用GORM

我们只需要在Goland的终端里依次运行下面两行命令,即可在IDE里使用GORM了
(我这里使用的数据库是mysql,所以第二个命令下载的driver是mysql的)

go get -u github.com/jinzhu/gorm
go get github.com/jinzhu/gorm/dialects/mysql@v1.9.16

在这里插入图片描述
在这里插入图片描述
这两行命令运行完成之后,任务其实已经完成了一半

使用Docker快速创建Mysql实例

如果不会安装MySQL或者懒得安装MySQL,可以使用一下命令快速运行一个MySQL8.0.19实例,当然前提是你要有docker环境(去官网下一个即可)

在本地的13306端口运行一个名为mysql8019,root用户名密码为root1234的MySQL容器环境:

docker run --name mysql8019 -p 13306:3306 -e MYSQL_ROOT_PASSWORD=root1234 -d mysql:8.0.19

然后再启动一个Mysql-client实例连接我们上面创建好的数据库环境,密码就是root1234

docker run -it --network host --rm mysql mysql -h127.0.0.1 -P13306 --default-character-set=utf8mb4 -uroot -p

在这里插入图片描述
运行完上面两行命令后,输入密码即可以使用Mysql了
在这里插入图片描述
输入密码之后,先创建一个名为db1的数据库

CREATE DATABASE DB1;

然后我们使用gorm连接DB1数据库进行CURD即可

package main

import (
	"fmt"
	"github.com/jinzhu/gorm"
	_"github.com/jinzhu/gorm/dialects/mysql"
)

type Userinfo struct {
	ID uint
	Name string
	Gender string
	Hobby string
}

func main()  {
	// 连接数据库
	db,err :=gorm.Open("mysql","root:root1234@(127.0.0.1:13306)/db1?charset=utf8mb4&parseTime=True&loc=Local")
	if err != nil{
		panic(err)
	}
	// 延迟关闭数据库
	defer db.Close()

	// 创建表 自动迁移(把结构体和数据表进行对应)
	// 比如我给USerinfo新增了一个字段,那么我们也会在数据库里添加对应的字段
	db.AutoMigrate(&Userinfo{})

	/* 1.创建数据行
	u1 := Userinfo{1,"zhl","male","gym"}
	db.Create(&u1)

	 */

	// 2.查询
	u := Userinfo{}
	db.First(&u) // 这个仅是其中一种查询方法,返回数据表第一行数据
	fmt.Printf("u:%#v\n",u)

	// 3.更新
	db.Model(&u).Update("hobby","NBA2K")

	// 4.删除
	db.Delete(&u)
}

我们可以简单归纳一下Go语言里面结构体和数据库的对应关系:

  1. 结构体——数据库表(Demo里的Userinfo其实就是数据库里表名为Userinfo的一张表)
  2. 结构体实例/对象——数据库行数据(Demo代码里的u1和u其实就是userinfo表里的一行数据)
  3. 结构体字段——数据库表字段(u1里面的id,name其实对应着表里面的id,name)

我们对上面的每一次操作都去终端里看一下执行结果,查看是否和我们计划一样
在这里插入图片描述

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-04-01 00:08:39  更:2022-04-01 00:11:02 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 15:03:38-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码