有没有办法从这个sql语句和逻辑中删除select count(*)
is there a way to remove the select count(*) from this sql statement and logic
我有一些C++代码,当一行存在时,它会更新一列,否则什么都不做。这是我的代码现在的样子,select count(*)大约需要15-20秒。我想让这个代码更有效率。
RunUpdateLockAliveTimeStamp
sCommand << "update APP_CC_LOCKS set ALIVETIMESTAMP = ";
sCommand << " SYSTIMESTAMP(7)";
sCommand << " where TRANSACTIONID = ?";
RunSelectCountDataCubeLock
sCommand << "select count(*) from APP_CC_LOCKS";
sCommand << " where (((SCENARIOID=? and YEARID=? and ENTITYID=? and PARENTID=? and VALUEID=?) and (LOCKTYPE = ?)) or (LOCKTYPE = ?)) and (TRANSACTIONID != ?) and ((TIMEINSERTED < (select MAX(TIMEINSERTED) from APP_CC_LOCKS ";
sCommand << " where TRANSACTIONID = ?)) or ((TIMEINSERTED = (select MAX(TIMEINSERTED) from ";
sCommand << “ APP_CC_LOCKS where TRANSACTIONID = ?)) and TRANSACTIONID <= ?))";
主
DWORD dwIterationNumber = 0;
// trying to accquire lock
cStartTime = DateTimeUtil::currentDateTimeAsMilliseconds();
while (bLockWasAcquired == false)
{
// try to accquire lock
numBlockingRecords = -1;
hr = cAccessor.RunSelectCountDataCubeLock(csTransID, lScenario, lYear, lEntity, lParent, lValue, &numBlockingRecords);
xfm_throw_propagate(FAILED(hr), hr);
// There's no block record then lock is temporary accquired until we resolve collision
if (numBlockingRecords == 0)
{
// The lock is now accquired
bLockWasAcquired = true;
break;
}
if (dwIterationNumber > g_lNumIterBeforeUpdatingTimeStamp)
{
//csSQLCmd.clear();
hr = cAccessor.RunUpdateLockAliveTimeStamp(csTransID);
xfm_throw_propagate(FAILED(hr), hr);
}
}
我不认为count(*)
是导致查询速度变慢的原因,而是where
子句中执行的两个子选择。
...((TIMEINSERTED < (select MAX(TIMEINSERTED) from APP_CC_LOCKS where TRANSACTIONID = ?))
or ((TIMEINSERTED = (select MAX(TIMEINSERTED) from APP_CC_LOCKS where TRANSACTIONID = ?))
可以用一个子选择取代:
((TIMEINSERTED <= (select MAX(TIMEINSERTED) from APP_CC_LOCKS where TRANSACTIONID = ?))
这可能会使执行时间减半。
相关文章:
- 将数组的地址分配给变量并删除
- 删除一个线程上有数百万个字符串的大型哈希映射会影响另一个线程的性能
- C/C++编译器通常会删除重复的库吗
- 从链接列表c++中删除一个项目
- C++如何通过用户输入删除列表元素
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 是否需要删除包含对象的"pair"?
- 如何在自删除后将对象设置为nullptr
- 迭代时从向量和内存中删除对象
- 使用函数"remove"删除重复元素
- 如何从多映射中删除特定的重复项
- 运算符C++ "delete []"仅删除 2 个前值
- 删除指向指针的指针是运行时错误吗
- 将指针设置为"nullptr"并不能防止双重删除?
- 为什么示例代码访问IUnknown中已删除的内存
- 如何通过 getter 函数删除矢量的元素?
- 从控制台中删除最后打印的元素
- C++中的线程安全删除
- 如何从存储在std::映射中的std::集中删除元素
- 有没有办法从这个sql语句和逻辑中删除select count(*)