zoukankan      html  css  js  c++  java
  • Python内置数据结构操作VS sqlite3操作

    1.摘要

    在同一数据库中查询某值,内置数据结构的查询速度快还是数据库sqlite3的查询速度快?针对这一问题,通过构建一个包含2500个随机数的列表,并将其插入sqlite3数据库中,利用timeit模块,分别对内置数据结构list和sqlite3查询某一值在不在数据组中进行对比。

    2.代码

    >>> import numpy as np
    >>> import sqlite3
    >>> test=np.random.randn(2500)
    >>> test=test.tolist()  #数据转换
    >>> a=test[100]  #待查询数据
    >>> conn=sqlite3.Connection('testit.db')
    >>> c=conn.cursor()
    >>> c.execute('create table test(ID integer primary key autoincrement,value real)')
    >>> for i in range(len(test)):
    	    c.execute('insert into test values (?,?)',(i,test[i]))  #需要注意的是,与占位符?对应的应该是元组,如果是只有一个?,则对应的元组也应该是(x,),其中x是需要插入的数据。
    >>> timeit.timeit('a in test',number=10000,globals=globals())  #globals=globals()保证了全局变量
    0.024695289129624598
    >>> timeit.timeit('c.execute("select * from test where test.value=?",(a,))',globals=globals(),number=10000)
    0.1466543038781083
    

     3.结论

    内置结构查询速度快。

    ##### 愿你一寸一寸地攻城略地,一点一点地焕然一新 #####
  • 相关阅读:
    Sort
    RAID
    LeetCode总结 -- 一维动态规划篇
    Count and Say
    Dynamic Programming Introduction
    Mongodb与Redis应用指标对比
    精通有状态vs无状态(Stateful vs Stateless)—Immutable模式之姐妹篇
    Windows 安装 pytorch3d
    GitHub 图片无法显示 或 gist 无法访问
    LaTeX符号表,数学公式速查必备
  • 原文地址:https://www.cnblogs.com/johnyang/p/12589479.html
Copyright © 2011-2022 走看看