最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

亲身体验MySQL的索引对搜索性能的提升_MySQL

来源:动视网 责编:小采 时间:2020-11-09 19:15:48
文档

亲身体验MySQL的索引对搜索性能的提升_MySQL

亲身体验MySQL的索引对搜索性能的提升_MySQL:1,创建一个user表,包含两列name,phone2,用python(你喜欢的任何语言)插入100W条记录(lz的笔记本比较老,大概用了1分钟吧):#!/usr/bin/env python# -*- coding:utf-8 -*-import MySQLdbconn =MySQLdb.connect(host
推荐度:
导读亲身体验MySQL的索引对搜索性能的提升_MySQL:1,创建一个user表,包含两列name,phone2,用python(你喜欢的任何语言)插入100W条记录(lz的笔记本比较老,大概用了1分钟吧):#!/usr/bin/env python# -*- coding:utf-8 -*-import MySQLdbconn =MySQLdb.connect(host


1,创建一个user表,包含两列name,phone

2,用python(你喜欢的任何语言)插入100W条记录(lz的笔记本比较老,大概用了1分钟吧):

#!/usr/bin/env python# -*- coding:utf-8 -*-import MySQLdbconn =MySQLdb.connect(host='localhost',user='root',db='millionMessage')cur = conn.cursor()for i in range(1,1000000):	uname = "user" + str(i)	uphone = "188000" + str(i)	sql = "insert into user(name,phone) values('%s','%s')" % (uname,uphone)	cur.execute(sql)conn.commit()cur.close()conn.close()

3,在没建立索引的情况下搜索:

mysql> select * from user where name='user55555';
+-------+-----------+-------------+
| uid | name | phone |
+-------+-----------+-------------+
| 55567 | user55555 | 18800055555 |
+-------+-----------+-------------+
1 row in set (0.53 sec)
mysql> select phone from user where name='user55555';
+-------------+
| phone |
+-------------+
| 18800055555 |
+-------------+
1 row in set (0.46 sec)

4,对name属性建立索引:

mysql> alter table user add index index_username(name);
Query OK, 0 rows affected (22.27 sec)
Records: 0 Duplicates: 0 Warnings: 0

5,查询:

mysql> select * from user where name='user55555';
+-------+-----------+-------------+
| uid | name | phone |
+-------+-----------+-------------+
| 55567 | user55555 | 18800055555 |
+-------+-----------+-------------+
1 row in set(0.00 sec)

mysql> select * from user where name='user999999';
+---------+------------+--------------+
| uid | name | phone |
+---------+------------+--------------+
| 1000011 | user999999 | 188000999999 |
+---------+------------+--------------+
1 row in set (0.00 sec)

结果秒出。可见在海量数据的数据库上,索引对搜索性能的提升是非常大的。

文档

亲身体验MySQL的索引对搜索性能的提升_MySQL

亲身体验MySQL的索引对搜索性能的提升_MySQL:1,创建一个user表,包含两列name,phone2,用python(你喜欢的任何语言)插入100W条记录(lz的笔记本比较老,大概用了1分钟吧):#!/usr/bin/env python# -*- coding:utf-8 -*-import MySQLdbconn =MySQLdb.connect(host
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top