SQL中联表的运用

当出现要大量数据去查询时,不要一个个去SQL查询,应该要批量的去查询。

def batch_cavity_query(self, fuseids):

"""批量查询cavity信息"""

if not fuseids:

return {}

复制代码
# 创建临时表批量查询
try:
    # 创建临时表
    self.cursor.execute("CREATE TABLE #TempFuseIDs (fuseid VARCHAR(100))")
    # 批量插入数据
    self.cursor.executemany("INSERT INTO #TempFuseIDs VALUES (%s)", [(fid,) for fid in fuseids])

    query = """
    SELECT 
        DA.qrc_fuseid,
        C.Barcode AS QRcode,
        L.qrc_fuseid AS LensData_FuseID,
        C.Cavity
    FROM #TempFuseIDs temp
    LEFT JOIN A DA
        ON temp.fuseid = DA.qrc_fuseid
    LEFT JOIN B L
        ON DA.qrc_QRcode = L.qrc_QRcode
    LEFT JOIN C C
        ON L.qrc_fuseid = C.Barcode
    """
    self.cursor.execute(query)
    results = self.cursor.fetchall()

    # 构建映射字典
    cavity_map = {}
    for row in results:
        fuseid = row[0]
        cavity_map[fuseid] = (row[1], row[2], row[3])

    return cavity_map
finally:
    self.cursor.execute("DROP TABLE #TempFuseIDs")
python 复制代码
def batch_query_sn(self, fuseids):
    """批量查询SN相关信息"""
    if not fuseids:
        return {}
复制代码
try:
    # 创建临时表
    self.cursor.execute("CREATE TABLE #TempFuseIDs (fuseid VARCHAR(100))")
    self.cursor.executemany("INSERT INTO #TempFuseIDs VALUES (%s)", [(fid,) for fid in fuseids])

    query = """
    SELECT 
        temp.fuseid,
        eqp_name,
        station_code,
        TRY_CAST(testres_main_test_recordposition3_ut_z AS FLOAT) - 
        TRY_CAST(testres_main_test_recordposition2_ut_z AS FLOAT) AS offset,
        time
    FROM #TempFuseIDs temp
    LEFT JOIN D  AA
        ON AA.sensor_id = temp.fuseid
    """
    self.cursor.execute(query)
    results = self.cursor.fetchall()

    sn_map = {}
    for row in results:
        fuseid = row[0]
        sn_map[fuseid] = (row[1], row[2], float(row[3]) if row[3] else 0, row[4])

    return sn_map
finally:
    self.cursor.execute("DROP TABLE #TempFuseIDs")
复制代码
相关推荐
IT龟苓膏1 小时前
Redis 数据类型底层原理:SDS、quicklist、intset、skiplist、Bitmap、HyperLogLog 一篇讲清
数据库·redis·skiplist
流星白龙1 小时前
【MySQL高阶】19.变更缓冲区,自适应哈希索引,日志缓冲区
数据库·windows·mysql
晴天¥2 小时前
Oracle中的监听配置与管理(动态、静态监听配置对比以及listener.ora和tnsnames.ora)
数据库·oracle
持敬chijing2 小时前
Web渗透之SQL注入-文件读写-木马植入
sql·安全·web安全·网络安全·安全威胁分析
瀚高PG实验室3 小时前
python连接HGDB超时
数据库·瀚高数据库·highgo
jnrjian3 小时前
ddl_lock_timeout 设置 read only table 通过view 实现细粒度依赖
sql·oracle
闪电悠米3 小时前
黑马点评-Redisson-01_why_redisson
java·服务器·网络·数据库·缓存·wpf
Counter-Strike大牛4 小时前
SpringBoot2.7.10+MyBatisPlus实现MySQL+DM双数据库切换
数据库·mysql
dllxhcjla4 小时前
Redis
数据库·redis·缓存
睡不醒男孩0308234 小时前
数据库高可用运维实操指南:基于CLup的PostgreSQL生产环境自动化管理
运维·数据库·postgresql