天天看點

C#中往資料庫插入/更新時候關于NUll空值的處理

今天碰到個問題。。SqlCommand對傳送的參數中如果字段的值是NULL具然不進行更新操作,也不提示任何錯誤。。。百思不得其解。。。先作個記錄,再查資料看看什麼原因。

暫時的解決方法:

1、Update不支援更新Null,先Delete後Insert來替換.

2、替代Null的方法,對于字元型,隻要是Null,改為空,語句中就是''.

找到了相關的解決方法

ADO.Net的Command對象如何向資料庫插入NULL值(原創)

一般來說,在Asp.Net與資料庫的互動中,通常使用Command對象,如:SqlCommand。通過Command對象對資料庫操作是相當安全和友善的(相對于RecordSet方式)。但是,同時發現了一個問題。像有些日期字段,如果使用者沒有選擇日期,我們希望他保持NULL狀态。我寫的關鍵代碼如下:

SqlCommand sqlCmd = new SqlCommand(sqlStatment, dbConn);

sqlCmd.Parameters.AddWithValue("@Name", name);

sqlCmd.Parameters.AddWithValue("@Surname", surname);

這時,雖未出錯,但傳回的影響行數告訴我。更新未成功。這是怎麼回事呢?

原來ADO.Net為了防止一些不容易找出的錯誤,在Command操作時加了一些限制。我們必須明确訓示Command對象,我們需要插入NUll值。修改後的代碼如下:

sqlCmd.Parameters[0].IsNullable = true;

sqlCmd.Parameters[1].IsNullable = true;

不過,還有一點要注意的就是,這裡的IsNullable,不是說你可以插入null值,而是指DBNull.Value值。

希望這點小經驗會對大家有幫助。

方法一、 

public int UpdateFeedBackStatus(int _feedBackID, int _status, object _RequestDateTime)

        {

            SqlParameter[] param = {

                                       new SqlParameter("@FeedBackID", _feedBackID),

                                       new SqlParameter("@FeedBackStatusID", _status),

                                       new SqlParameter("@RequestDateTime", _RequestDateTime)

                                    };

            StringBuilder strSql = new StringBuilder();

            strSql.Append("UPDATE dbo.FeedBack ");

            strSql.Append("SET FeedBackStatusID=@FeedBackStatusID,RequestDateTime=@RequestDateTime ");

            strSql.Append("WHERE FeedBackID=@FeedBackID ");

            return DbHelper.ExecuteNonQuery(CommandType.Text,strSql.ToString(),param);

        }

調用:

 feedBackBLL.UpdateFeedBackStatus(_feedBackID, 4, DBNull.Value);

 或者feedBackBLL.UpdateFeedBackStatus(_feedBackID, 4,null);

方法二:

  public int UpdateFeedBackStatus(int _feedBackID, int _status, DateTime? _RequestDateTime)

                                   };

            param[2].IsNullable = true;

 feedBackBLL.UpdateFeedBackStatus(_feedBackID, 4,null);

在用C#往資料庫裡面插入記錄的時候, 可能有的字段你不指派,那麼這個字段的值就為null, 如果按一般想法的話,這個值會被資料庫接受, 然後在數 據表裡面顯示為NUll, 實際上這就牽扯到一個類型的問題, C#中的NUll于SQL中的null是不一樣的, SQL中的null用C#表示出來就 是DBNull.Value, 是以在進行Insert的時候要注意的地方.

Example:

       SqlCommand cmd=new  SqlCommand("Insert into Student values(@StuName,@StuAge)" ,con);

       cmd.parameters.add("@StuName" ,stuname);

       cmd.parameters.add("@StuAge" ,stuage);

       cmd.ExecuteNonQuery();

這些代碼看似沒有問題, 其實當stuname于stuage中的任何一個值為null的時候, 這代碼就會報錯...汗!!!

解決辦法:

        其實最簡單的辦法就是進行判斷, 當stuname或stuage為空時, 插入DBNull.Value.

        但是這樣當一個資料庫有很多字段時或者是有很多張表時, 代碼就會很多了,我也沒有找到特别友善的方法,我的方法是:寫一個靜态的方法來對變量的值進行判斷:

Example :     

        static  public  object  SqlNull(object  obj)

            if  (obj == null )

                return  DBNull.Value;

            return  obj;

       //用上面的方法對參數進行了判斷 

       cmd.parameters.add("@StuName" ,SqlNull(stuname));

       cmd.parameters.add("@StuAge" ,SqlNull(stuage));