(1)不要在析構函數中.Close()數據層。
(2)盡量不要使用復雜的列表控件,太大,按照需求來,在.NET中,注重的是控件編程,就是非字符串輸出的編程,衍生的就是時間,委托等,很多時候,繼承IX接口編寫自己的,這樣可能更適合。
(3)
using System;
public sealed class Singleton
{
private static volatile Singleton instance;
private static object syncRoot = new Object();
private Singleton() {}
public static Singleton Instance
{
get
{
if (instance == null)
{
lock (syncRoot)
{
if (instance == null)
instance = new Singleton();
}
}
return instance;
}
}
}
這樣Get對象較好。
(4)在一個Connection對象中,如果已經創建了SqlCommand的Conntion的對象,當記錄打開要執行的時候,如果再跳出執行,上一操作將被執行兩次,這如c++裡面的inline.
(5)sp_help是個好東西,sp_x都很不錯。
(6)MSSQL重設字段編號標識列:
USE MyDataBase
GO
DBCC CHECKIDENT (MyTable, NORESEED)
GO
OR:
USE MyDatabase
GO
DBCC CHECKIDENT (MyTable, RESEED, 1)
GO
(7)Object reference not set to an instance of an object這個異常經常產生的原因不一:
主要有:Session不穩定,對於對象的獲取,先判斷是否是null,然後再用IsEmpty判斷。