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不是太高
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 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错误处理封装