mysql测试记录

一直觉得mysql的Memony内存引擎挺好,其他数据库都没有,正好有空,所以试试。

 

版本:mysql-installer-community-8.0.17.0

os:windows10 SSD硬盘,本机访问

 

简单表,一个ID字段为主键,一个字符串字段

 

1. Memony引擎

单条插入10000条耗时18s,批量事务提交插入10000条耗时18s。

 

2. Myisam引擎

单条插入10000条耗时19s,批量事务提交插入10000条耗时19s。

 

3. InnoDB引擎

单条插入10000条耗时40s,批量事务提交插入10000条耗时2s。

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
private void button1_Click(object sender, EventArgs e)
       {
           //删除
           DateTime d = DateTime.Now;
           string sql = "delete from " + this.textBox1.Text;
           MySqlConnection cn = new MySqlConnection(this.connstring);
           cn.Open();
           MySqlCommand cmd = new MySql.Data.MySqlClient.MySqlCommand(sql, cn);
           cmd.ExecuteNonQuery();
           cn.Close();
 
           this.textBox2.Text = (DateTime.Now - d).TotalMilliseconds.ToString();
       }
 
       private void button2_Click(object sender, EventArgs e)
       {
           //单条增加
           DateTime d = DateTime.Now;
           MySqlConnection cn = new MySqlConnection(this.connstring);
           cn.Open();
           string sql = "insert into " + this.textBox1.Text + "(a,v) values({0}, '{1}')";
           for (int m = 0; m < 10000; m++)
           {
               string s = string.Format(sql, m, System.Guid.NewGuid().ToString() + "在");
               MySqlCommand cmd = new MySql.Data.MySqlClient.MySqlCommand(s, cn);
               cmd.ExecuteNonQuery();
           }
           cn.Close();
 
           this.textBox2.Text = (DateTime.Now - d).TotalMilliseconds.ToString();
       }
 
       private void button3_Click(object sender, EventArgs e)
       {
           //单条增加
           DateTime d = DateTime.Now;
           MySqlConnection cn = new MySqlConnection(this.connstring);
           cn.Open();
           MySqlTransaction tran = cn.BeginTransaction();
           string sql = "insert into " + this.textBox1.Text + "(a,v) values({0}, '{1}')";
           for (int m = 0; m < 10000; m++)
           {
               string s = string.Format(sql, m, System.Guid.NewGuid().ToString() + "在");
               MySqlCommand cmd = new MySql.Data.MySqlClient.MySqlCommand(s, cn);
               cmd.Transaction = tran;
               cmd.ExecuteNonQuery();
           }
           tran.Commit();
           cn.Close();
           this.textBox2.Text = (DateTime.Now - d).TotalMilliseconds.ToString();
       }
 
       private void button4_Click(object sender, EventArgs e)
       {
           //查询
           MySqlDataAdapter da = new MySqlDataAdapter("select * from " + this.textBox1.Text, this.connstring);
           DataSet ds = new DataSet();
           da.Fill(ds, "t");
           this.dataGridView1.DataSource = ds.Tables[0].DefaultView;
       }

 

下面N多年前的测试,可做对比:

https://www.cnblogs.com/81/archive/2009/07/31/1535694.html

https://www.cnblogs.com/81/archive/2008/12/06/1348896.html

感觉mysql不是太高

 

posted @   81  阅读(204)  评论(1编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
历史上的今天:
2006-08-16 asp.net错误处理封装
点击右上角即可分享
微信分享提示