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 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> mysql 分库分表实战 -> 正文阅读

[大数据]mysql 分库分表实战

1、生成1000w条数据。

如果用代码,会很久。1w条用了1分钟,1000w条数据估计1000分钟。

下面直接用存储过程。

?发现插入10000条数据用了0.9s, 插入10w条数据用了4.7s, 插入100w条数据用了58s左右,1000w条数,参考文章https://www.jb51.net/article/207999.htm

?事先先创建一个表

CREATE TABLE `users` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) DEFAULT NULL,
  `home` varchar(255) DEFAULT NULL,
  `balance` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=100001 DEFAULT CHARSET=utf8mb4;
登录mysql客户端 依次输入如下。
use test
delimiter "$"

 create procedure bathInsert(in args int)
    -> begin
    -> declare i int default 1;
    -> start transaction;
    -> while i <= args do
    -> insert into users(id,name,home,balance) value(i,"dgx","shengzheng","level-go");
    -> set i = i+1;
    -> end while;
    -> commit;
    -> end
    -> $

call bathInsert(10000000);$


即快速生成了1000w条数据。耗时1 min 14.77 sec)。

Query OK, 0 rows affected (1 min 14.77 sec)

如果name不一样,用concat函数,也可以在navicat那里编辑输入

CREATE DEFINER=`root`@`localhost` PROCEDURE `bathInsert2`(in args int)
begin
declare i int default 1;
start transaction;
while i <= args do
insert into users(id,name,home,balance) value(i,concat("dgx",i),"shengzheng","level-go");
 set i = i+1;
end while;
commit;
end

SELECT * FROM users WHERE `name` ='dgx1214000'? 没有用索引 耗时 2s.035多一点点。

解决方案一:

如果是sql语句,添加上:

UNIQUE KEY `name_index` (`name`) USING BTREE COMMENT '名字索引'

解决方案二:

import (
	"database/sql"
	"fmt"
	_ "github.com/go-sql-driver/mysql" //执行init(),注册mysql驱动
	"hash/crc32"
	"strconv"
	"time"
)
func main() {
	//方案二:用go语言官方自带驱动
	dsn := "root:root@tcp(127.0.0.1:3306)/goinsum"
	db, err := sql.Open("mysql", dsn)
	if err != nil {
		panic(error.Error(err))
	}
	fmt.Println("parameter verification succeeded!")
	//MakeHashTrans(db)
	ShardingSingle(db)

}

func MakeHashTrans(db *sql.DB) {
	rows, err := db.Query("select * from users")
	cloumns, err := rows.Columns()
	if err != nil {
		fmt.Println(err)
	}
	// 定义10个变量,分别存储不同的拼接内容,分别计数,如果到了10000,就批量插入数据库。
	var resultkey = [10]string{}
	var resultkeylast = [10]string{}
	var count = [10]int{}

	fmt.Println(resultkey)
	for rows.Next() {
		err := rows.Scan(&cloumns[0], &cloumns[1], &cloumns[2], &cloumns[3])
		if err != nil {
			fmt.Println(err)
		}
		result := "(" + cloumns[0] + ",'" + cloumns[1] + "','" + cloumns[2] + "'," + "'" + cloumns[3] + "'" + ")" + ","

		fmt.Println(cloumns[0])
		hashValue := crc32.ChecksumIEEE([]byte(cloumns[1]))
		tableId := hashValue % 10
		fmt.Println(tableId)
		a := int(tableId)
		count[a] = count[a] + 1
		fmt.Println(count[a])
		resultkey[a] = resultkey[a] + result
		// 积累到了10000,就批量插入数据库
		if count[a] == 100000 {
			resultkeylast[a] = resultkey[a][0 : len(resultkey[a])-1]
			qry := "insert into user_" + strconv.Itoa(a) + " (`uid`, `name`, `home`, `balance`) values" + resultkeylast[a]
			//fmt.Println(qry)
			_, err = db.Exec(qry)
			if err != nil {
				fmt.Println(err)
			}
			// 清零处理
			count[a] = 0
			resultkey[a] = ""
		}
		fmt.Printf("a ==%d,count[a]==%d", a, count[a])

	}

}

// 性能大PK,
func ShardingSingle(db *sql.DB) {
	//未分表搜索
	//SELECT * from users WHERE name = 'dgx51322'
	name := "dgx51322"

	st1 := time.Now()
	row, _ := db.Query("select * from users where name = '" + name + "'")
	fmt.Println("single query unsharding spend time:", time.Since(st1))
	cloumn1, err := row.Columns()
	if err != nil {
		fmt.Println(err)
	}
	for row.Next() {
		row.Scan(&cloumn1[0], &cloumn1[1], &cloumn1[2], &cloumn1[3])
		fmt.Println(cloumn1)
	}

	//分表搜索
	a := crc32.ChecksumIEEE([]byte(name)) % 10
	qryString := "select * from user_" + strconv.Itoa(int(a)) + " where name = '" + name + "'"
	st2 := time.Now()
	row2, _ := db.Query(qryString)
	fmt.Println("single query sharding spend time:", time.Since(st2))
	cloumn2, _ := row2.Columns()
	for row2.Next() {
		row2.Scan(&cloumn2[0], &cloumn2[1], &cloumn2[2], &cloumn2[3], &cloumn2[4])
		fmt.Println(cloumn2)
	}
	return
}

性能大pk,比较:

parameter verification succeeded!
single query unsharding spend time: 2.1368947s
[51322 dgx51322 shengzheng level-go]
single query sharding spend time: 1.5661ms
?

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-04-01 23:28:20  更:2022-04-01 23:30:31 
 
开发: 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 14:51:31-

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