我使用的数据库是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使这些查询更快。
如果你被允许在数据库中创建一个表,就创建一个表。
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"
;