golang:Excel写入mysql数据库

要将读取的每个Sheet中的数据分别写入不同的MySQL数据库,你需要使用Go语言的MySQL数据库驱动,以及合适的数据库连接和插入逻辑。在Go中,可以使用github.com/go-sql-driver/mysqlgithub.com/jmoiron/sqlx等库来处理MySQL数据库连接和操作。

首先,你需要安装这几个库:

Go 复制代码
go get github.com/go-sql-driver/mysql
go get github.com/jmoiron/sqlx
go get github.com/tealeg/xlsx

然后,你可以使用以下代码示例将每个Sheet的数据写入不同的MySQL数据库:

Go 复制代码
package main

import (
	"database/sql"
	"fmt"
	"github.com/go-sql-driver/mysql"
	"github.com/jmoiron/sqlx"
	"github.com/tealeg/xlsx"
)

// MySQLConfig 包含MySQL数据库连接配置
type MySQLConfig struct {
	Username string
	Password string
	Host     string
	Port     string
	Database string
}

// WriteSheetDataToMySQL 将Sheet的数据写入MySQL数据库
func WriteSheetDataToMySQL(mysqlConfig MySQLConfig, sheet *xlsx.Sheet) error {
	// 构建MySQL连接字符串
	dataSourceName := fmt.Sprintf("%s:%s@tcp(%s:%s)/%s",
		mysqlConfig.Username, mysqlConfig.Password, mysqlConfig.Host, mysqlConfig.Port, mysqlConfig.Database)

	// 连接MySQL数据库
	db, err := sqlx.Open("mysql", dataSourceName)
	if err != nil {
		return fmt.Errorf("Error connecting to MySQL: %s", err)
	}
	defer db.Close()

	// 遍历每一行
	for _, row := range sheet.Rows {
		// 遍历每个单元格
		// 这里假设每一行的数据对应数据库表的字段,可以根据实际情况调整
		var field1, field2 string
		for colIndex, cell := range row.Cells {
			text := cell.String()
			switch colIndex {
			case 0:
				field1 = text
			case 1:
				field2 = text
			// 可以根据实际情况添加其他字段
			}
		}

		// 执行插入操作,这里假设表名为 "example_table"
		_, err := db.Exec("INSERT INTO example_table (field1, field2) VALUES (?, ?)", field1, field2)
		if err != nil {
			return fmt.Errorf("Error inserting data into MySQL: %s", err)
		}
	}

	return nil
}

func main() {
	excelFileName := "path/to/your/excel/file.xlsx"

	// 读取Excel文件
	xlFile, err := xlsx.OpenFile(excelFileName)
	if err != nil {
		fmt.Printf("Error opening Excel file: %s\n", err)
		return
	}

	// MySQL数据库配置
	mysqlConfig := MySQLConfig{
		Username: "your_username",
		Password: "your_password",
		Host:     "localhost",
		Port:     "3306",
		Database: "your_database",
	}

	// 遍历每个工作表,并将数据写入MySQL数据库
	for _, sheet := range xlFile.Sheets {
		err := WriteSheetDataToMySQL(mysqlConfig, sheet)
		if err != nil {
			fmt.Printf("Error writing data to MySQL: %s\n", err)
			return
		}
	}
}

请确保修改MySQLConfig结构体中的数据库连接信息,并根据实际情况修改插入操作的SQL语句和字段映射。上述示例假设Excel文件中的每一行数据对应MySQL表中的字段,这可能需要根据实际情况进行调整。

相关推荐
万岳科技系统开发13 分钟前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
冉冰学姐26 分钟前
SSM智慧社区管理系统jby69(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·管理系统·智慧社区·ssm 框架
杨超越luckly33 分钟前
HTML应用指南:利用GET请求获取中国500强企业名单,揭秘企业增长、分化与转型的新常态
前端·数据库·html·可视化·中国500强
斯普信专业组40 分钟前
构建基于MCP的MySQL智能运维平台:从开源服务端到交互式AI助手
运维·mysql·开源·mcp
Elastic 中国社区官方博客41 分钟前
Elasticsearch:Workflows 介绍 - 9.3
大数据·数据库·人工智能·elasticsearch·ai·全文检索
仍然.1 小时前
MYSQL--- 聚合查询,分组查询和联合查询
数据库
一 乐1 小时前
校园二手交易|基于springboot + vue校园二手交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
啦啦啦_99991 小时前
Redis-0-业务逻辑
数据库·redis·缓存
自不量力的A同学1 小时前
Redisson 4.2.0 发布,官方推荐的 Redis 客户端
数据库·redis·缓存
Exquisite.1 小时前
Mysql
数据库·mysql