C# ODBC。提高数千次选择查询的性能

问题描述 投票:0回答:1

我使用的数据库是Progress OpenEdge。在我的程序中,我抽取了数千个序列号,并在数据库中查询与它们相关的信息。

本质上,下面这段代码需要大约6000个序列号,并为每个序列号创建一个选择查询,并返回一个包含字符串的列表。

/// <summary>
/// Builds a list of queries for each serial number in param<c>sn</c>
/// </summary>
/// <param name="sn">A list of valid serial numbers</param>
/// <returns>A list of strings where each string is a sql query for a serial number's information</returns>
private static List<string> BuildQuery(List<string> sn)
   {
      return sn.Select(s => "SELECT a.\"Date-Created\", a.\"date-produced\", a.employee, " +
                            "a.\"Item-Code\", a.\"job-number\", a.\"station-produced\", " +
                            "a.\"shift-produced\", a.\"Serial-Number\", a.\"parent-serial\", " +
                            "a.\"gross-wgt\", a.\"qty-base\", a.\"resin-wgt\", " +
                            "a.\"tare-wgt\", a.\"Integer-1\", a.\"unit-number\" FROM " +
                            $"CUSTOM10.PUB.\"imsngsnt\" a WHERE a.\"Serial-Number\" = '{s}'").ToList();
   }

然后我在列表中循环调用这个函数约6000次。

/// <summary>
/// Makes a query to the given connection <c>conn</c> and query <c>sql</c> and returns the information for the serial number <c>sn</c>
/// </summary>
/// <param name="conn">Connection to SNT database</param>
/// <param name="sql">SQL query</param>
/// <param name="sn">The serial number the query pertains to</param>
/// <returns><c>SerialInformation</c> containing the information for Serial number <c>sn</c></returns>
private static SerialInformation MakeQuery(OdbcConnection conn, string sql, string sn)
   {
       var set = new DataSet();
       // Perform all queries
       var adapter = new OdbcDataAdapter(sql, conn);

       adapter.Fill(set);
       if (set.Tables[0].Rows.Count == 0) return null;
       var info = ConvertDataSet(set);
       // Add starting serial number to info
       info.StartingSerial = sn;
       return info;
    }

我知道这是非常低效的,我想知道如何使用.NET System.Data.ODBC使这些查询更快。

c# sql .net-core odbc openedge
1个回答
1
投票

如果你被允许在数据库中创建一个表,就创建一个表。

CREATE TABLE search_serial_numbers (
  "Serial-Number" INTEGER 
  -- or is it VARCHAR(n)? 
  -- EXACT SAME TYPE AS "Serial-Number" in the 
  -- CUSTOM10.PUB."imsngsnt" table!
);

然后,在一个SQLExecute()的调用中 把大约6000行的数据插入到数据库中 search_serial_numbers 表。

然后,去--(我会用纯SQL写,你可以根据需要从C#中连接字符串)。

SELECT 
  a."Date-Created"
, a."date-produced"
, a.employee
, a."Item-Code"
, a."job-number"
, a."station-produced"
, a."shift-produced"
, a."Serial-Number"
, a."parent-serial"
, a."gross-wgt"
, a."qty-base"
, a."resin-wgt"
, a."tare-wgt"
, a."Integer-1"
, a."unit-number"
FROM CUSTOM10.PUB."imsngsnt" a 
INNER JOIN search_serial_number b
on a."Serial-Number" = b."Serial-Number"
;
© www.soinside.com 2019 - 2024. All rights reserved.