社区
C#
帖子详情
c# 一个for循环速度太慢的问题
雪绒花痴
2021-03-03 04:17:34
一个for循环,循环的值都要在sqlserver数据库进行查询验证是否有无。
能成功循环,就是一旦循环的值多了速度就会很慢,有什么不改变验证数据库的前提下,进行加快速度
...全文
3831
21
打赏
收藏
c# 一个for循环速度太慢的问题
一个for循环,循环的值都要在sqlserver数据库进行查询验证是否有无。 能成功循环,就是一旦循环的值多了速度就会很慢,有什么不改变验证数据库的前提下,进行加快速度
复制链接
扫一扫
分享
转发到动态
举报
AI
作业
写回复
配置赞助广告
用AI写文章
21 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
冰思雨
2021-03-09
打赏
举报
回复
1
优化步骤: 1. 建立数据库连接池,不要每次操作都建立和关闭数据库连接。 每个连接,数据库端都会有操作的缓存以及数据的缓存,可以优化你的SQL执行效率。 新的连接里面没有上几次执行的语句和数据,无法让数据库进一步的进行优化。 2. 循环体中每次查询都只能查出一条数据,可以重新设计查询语句,一次性将循环体中所有要查询的数据查出来。 一个循环体要执行100次的循环,每次循环都查询出一条记录。 可以改为,循环之前,一次性查出一百个记录,然后,循环体中逐个处理查询结果。 这样做,在逻辑上是等价的,但是,效率上会更高,省去了99次的交互和查询过程。 3. 如果不能一次性查出所有循环体中需要的记录(实际上是可以一次性全查询出来的),还有一种优化的方向, 看看目标表中 b_deal=0 的记录条数有多少,如果少于几百上千条的话,可以一次性读取到内存当中,将这些数据进行缓存, 然后,循环体内就不用再查了,直接从内存中访问。 当然了,这种方案在这里是并不推荐的,因为步骤2是可以实现的。两者异曲同工。
xinw_liu1111
2021-03-08
打赏
举报
回复
寻址方法不好。。
小沐CA
2021-03-08
打赏
举报
回复
其一,速度都耽误在闭合上面了,可以用批量处理的方式来处理循环。其二就是换掉if循环
小沐CA
2021-03-08
打赏
举报
回复
其一,速度都耽误在闭合上面了,可以用批量处理的方式来处理循环。其二就是换掉if循环
xiaoxiangqing
2021-03-08
打赏
举报
回复
可以把语句拼接起来,用in来代替
m0_55844471
2021-03-07
打赏
举报
回复
努力vis提升自己vulnerable
心蓝168
2021-03-06
打赏
举报
回复
由于已知从哪个表查询,还有查询条件i的值已定,可以直接先把查询出来,然后再循环处理number的值。 即:select boxindex/100 from dbo.Meter_** where b_deal=0 and boxindex in (.......),这样就可以只操作一次数据,然后再循环求number的值
千秋的秋千丶
2021-03-05
打赏
举报
回复
如何增加积分啊?
duangufei
2021-03-05
打赏
举报
回复
直接用in查询,boxindex in('XXXX'),外面循环拼接XXX,一条sql语句就都出来了
changjiangzhibin
2021-03-05
打赏
举报
回复
一般情况下,数据量特别大的需要另外处理。一次查出所有数据,然后根据条件在查出的数据中进行筛选和处理
三人行我
2021-03-05
打赏
举报
回复
sql里的merge into
正怒月神
2021-03-04
打赏
举报
回复
先说说,你要实现的是什么
datafansbj
2021-03-04
打赏
举报
回复
建议使用如下算法:
1、将循环体的值先保存到 DataTable 中
2、开启数据库事务
3、在数据库中建立临时表
4、使用 SqlBulkCopy 组件将 DataTable 的数据一次性导入到数据库的临时表
5、使用 SQL 语句处理临时表的数据
6、将处理的结果使用 SQL 查询出来
7、提交事务
所有需要多次与数据库交互的场景均可以使用上述机制处理,比循环交互快得多。
不会打字的猫
2021-03-04
打赏
举报
回复
你先把数据查出来,在外面判断,或者写个存储过程,在过程里面判断,你这循环一次连一次~不慢也得慢了
xugq979
2021-03-03
打赏
举报
回复
1、循环前 把需要的数据查出来(数据量级不是很大的前提)。 2、循环内 用查出来的数据集进行 有效性验证。 这样 数据库只查询一次。
much0726
2021-03-03
打赏
举报
回复
数据库的开关是比较耗时间的,可以考虑多语句,或者存储过程,一次性提交
大葡萄八块一斤
2021-03-03
打赏
举报
回复
直接搞个存储过程,你传递下minnum跟maxnum参数,让存储过程去验证返回结果,还有你的sdr根本没用。。。每一遍都执行了两次select语句。
石岩Maple
2021-03-03
打赏
举报
回复
一些没必要的计算和判断用代码来做,减少查询数据库的次数,速度自然上来了
石岩Maple
2021-03-03
打赏
举报
回复
用批处理语句,不要每次循环就查一个,查100次和查1次效率肯定不一样
真相重于对错
2021-03-03
打赏
举报
回复
不要频繁打开关闭数据库连接
加载更多回复(1)
c#
Duff优化for
循环
耗时
看Js高级编程的时候 发现了
一个
叫duff 可以优化for
循环
的 感觉比较有趣简单 写了
一个
c#
版的 winfrom的三个button的代码如下 如果要效果明显 可以增大for
循环
长量的值 public const int Counts= 10000000; private void button1_Click(object sender, EventArg
探讨如何加快
C#
双
循环
的
速度
效率
最近使用
C#
改写以前编的
一个
程序,检索数据赋值时,使用 FOR
循环
结构,当数据量在9万条时,计算量很大,导致很耗时,何况计算完成同时加载到 chart 和 dataGridView 图表控件中(没有使用第三方控件),于是百度了很多
循环
手段。
c#
循环
提速
当你需要频繁查找元素时, Dictionary或者Hashtable的查找
速度
通常要比List快。这是因为它们通过哈希码直接访问元素,时间复杂度为O(1)。: 当处理大量数据并且操作之间没有依赖关系时,可以使用Parallel.ForEach进行并行处理以提高效率。: 对于 ** 遍历,foreach通常比显式索引的for
循环
更高效,因为它避免了索引操作和边界检查。: 如果
循环
条件涉及到复杂的计算,考虑在
循环
外部预计算。
c语言for
循环
变慢,C语言中for
循环
问题
(
一个
小坑需注意)
今天分享一下C语言中的for
循环
中我们常常忽略的小
问题
。举
一个
小例子来说明,大家也可以自己先算一下哦#define _CRT_SECURE_NO_WARNINGS#include #include int main(){int a=0;int b=0;for(a=0,b=0;b=0;a++,b++)b++;return 0;}这是一道面试题,问程序运行几次呢?运行结果如何?其实这个小题关键是我们有...
C#
如何优化
循环
Parallel.For 提供了取消令牌(CancellationToken)和异常处理机制,使得开发者可以在需要时中断
循环
,并处理并行执行过程中可能出现的异常,增强了代码的鲁棒性和灵活性。相比于传统的 for
循环
,它可以显著缩短执行时间。Parallel.For 的使用方式和普通的 for
循环
非常相似,因此开发者可以很容易地将现有的串行代码转换为并行执行,减少了学习和使用成本。Parallel.For 自动管理线程的创建和销毁,开发者无需手动管理线程池或创建和销毁线程,简化了并行编程的复杂性。
C#
111,092
社区成员
642,554
社区内容
发帖
与我相关
我的任务
C#
.NET技术 C#
复制链接
扫一扫
分享
社区描述
.NET技术 C#
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
让您成为最强悍的C#开发者
试试用AI创作助手写篇文章吧
+ 用AI写文章