c# - 如何在 Qt 中更快地读取数据?

标签 c# qt

Qt 读取数据库是否比 C# 慢?我想我错过了什么!为了比较阅读速度,我在 Qt 中写了以下内容

QElapsedTimer t;
t.start();
int count = 0;
QString cs = "Driver={SQL Server}; Server=EMON;Database=FAODB;User=Test;Password=Test";
QSqlDatabase db = QSqlDatabase::addDatabase("QODBC",cs);
db.setDatabaseName(cs);
db.open();
QSqlQuery query(db);
query.setForwardOnly(true);
query.exec("SELECT * FROM FAOCropsLivestock");
while(query.next()){
    if(query.value("Country").toString() == "\"Bangladesh\"")
        count++;
}
db.close();
qDebug()<< QString::number(count) + " elapsed ms " + QString::number(t.elapsed());

在 C# 中

Stopwatch s = new Stopwatch();
s.Start();
int count = 0;
string cs = ConfigurationManager.ConnectionStrings["DB"].ConnectionString;
string query = "SELECT * FROM FAOCropsLivestock";
using(SqlConnection con = new SqlConnection(cs)){
      using(SqlCommand cmd = new SqlCommand(query, con)){
            con.Open();
            SqlDataReader rd = cmd.ExecuteReader();
            while (rd.Read()){
                  if(rd["Country"].ToString() == "\"Bangladesh\"")
                        count++;                       
            }
      }
}
s.Stop();
Console.WriteLine(count + " elapsed ms " + s.ElapsedMilliseconds);

C# 和 Qt 都适用于 x86 并且处于 Release模式。

在 Qt 的例子中,结果是 "63653 elapsed ms 68213" 在 C# 中 "63653 elapsed ms 14210"


对于Qt版本我已经替换了

QString cs = "Driver={SQL Server}; Server=EMON;Database=FAODB;User=Test;Password=Test";
QSqlDatabase db = QSqlDatabase::addDatabase("QODBC",cs);
db.setDatabaseName(cs);

通过

QSqlDatabase db = QSqlDatabase::addDatabase("QODBC" /*QODBC3*/);
db.setDatabaseName("Driver={SQL Server Native Client 11.0};"\
                   "Server=EMON;Database=FAODB;Uid=Test;Pwd=Test;");

结果在 58 秒到 71 秒之间。

最佳答案

对于您的 C# 版本,您不显示连接字符串。您是否为两者使用相同的驱动程序?我不是这方面的专家,但我的同事说“SQL Server”驱动程序非常非常旧而且速度很慢。您可能想尝试“SQL Native Client”或类似的东西。无论哪种方式,请确保测试使用相同的 SQL 驱动程序。

关于c# - 如何在 Qt 中更快地读取数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41192841/

相关文章:

linux - 解释段错误消息

c++ - 无法将 C++ 类型转换为 QML

c# - TestContext 名称与给定代码有何关联?

c# - WPF - 如何访问 App.xaml.cs 中声明的方法?

c# - 系统.InvalidOperationException : Missing parameter

c++ - qt按住鼠标按钮和定时器cpp

c++ - QHBoxLayout间距

c# - 在 F# 语言中覆盖 C# 类中的方法会使该方法不可自省(introspection)?

c# - 在不加载的情况下按条件更新数据库表中的字段

c++ - QtConcurrent::run() 不接受 __stdcall/WINAPI 函数