SQLSERVER大批量数据操作时所占用内存释...
现象:
现在做一个程序,对数据库的几个装有大量数据的表进行操作,对其中的一个表进行
循环操作,以处理其他的几个表。其中用到了几个query,update,当程序跑的过程中,
SQLSERVER的内存不断的增长,跑完后关闭程序退出后也不降下来。
解决:
这是SQL的内存管理机制决定的,SQL管理内存的原则是这样的,只要你的内存够用(这个够用是指你分配给SQL的可用内存),则SQL不会释放占用的内存,新的操作会分配新的内存,直到分配完可用的内存后,才会释放内存,因为内存占用会一直上涨,直到达到极限
解决的方法是限制给SQL的可用内存量
另外,对于频繁操作数据库的操作,不要每一次都去getConnection,然后再close,这样是很消耗内存的,sql server的内存会持续增长,即使每次都对connection做了close,sql server的内存还是会不停增长,虽然sql server会自动调节,不会让系统死掉,但是内存太少,做任何操作都会变的很慢了。可行的办法是,对于频繁的数据库操作,根据执行的类型,比如按select、update、insert来分类,在内存中建立staitc Connection,让这些频繁的操作,也就是说减少Connection的建立数量,这样就会大幅度的降低内存的消耗量,内存几乎不增长了,问题就解决了。
相关文档:
SQLServer
: EXEC和sp_executesql的区别
摘要
1,EXEC的使用
2,sp_executesql的使用
MSSQL为我们提供了两种动态执行SQL语句的命令,分别是EXEC和sp_executesql;通常,sp_executesql则更具有优势,它
提供了输入输出接口,而EXEC没有。还有一个最大的好处就是利用sp_ ......
进来因为开发原因,经常需要使用日期方面的比较和操作,整理了一下这方面的资料,供大家共享:
SQL Server中文版的默认的日期字段datetime格式是yyyy-mm-dd Thh:mm:ss.mmm
例如:
select getdate()
2004-09-12 11:06:08.177
整理了一下SQL Server里面可能经常会用到的日期格式转换方法:
举例如下:
select CONVE ......
/*
*SQLServer添加操作实现
*/
void CMFCSQLDlg::OnButton2()
{
// TODO: Add your control notification handler code here
CString strsql;
CString strnum="mynum3";
CString strage="myage3";
HRESULT hResult;
_variant_t RecordsAffected;
CoInitialize(NULL);
_ConnectionPtr m_pAppConn;
hResul ......
Access、SQLServer、Oracle常见SQL语句应用区别
关劲松 PMP
如果要兼容Access、SQL Server、Oracle三个数据库版本;我们在编写SQL语句的过程中,尽量使用一些通用的语句,但还是有些方面有些区别避免不了,现简单总结一下。
以下A代表Access,S代表SQL Server,O代表Oracle
1、取当前系统时间
A:Select Now()
S:Selec ......