網(wǎng)站首頁 編程語言 正文
插入或更新null空值
一、在SQL語句中直接插入null或空字符串“”
int? item = null;
item == null ?
"null"
: item.ToString();
item == null ? "" : item.ToString();
二、用命令參數(shù),插入DBNull.Value
int? item = null;
cmd.Parameters.Add(dbPams.MakeInParam(":Item", SqlNull(item)));
cmd.Parameters[0].IsNullable = true;//更新時需加入此句。
static public object SqlNull(object obj)
{
return (item == null ? DBNull.Value : item)
}
延遲加載
.在.NET4.0中,可以使用Lazy 來實現(xiàn)對象的延遲初始化,從而優(yōu)化系統(tǒng)的性能。
正如我們所知,對象的加載是需要消耗時間的,特別是對于大對象來說消耗的時間更多.lazy可以實現(xiàn)對象的延遲加載。延時加載,意思是對象在使用的時候創(chuàng)建而不是在實例化的的時候才創(chuàng)建。
Lazy 對象初始化默認是線程安全的,在多線程環(huán)境下,第一個訪問 Lazy 對象的 Value 屬性的線程將初始化 Lazy 對象,以后訪問的線程都將使用第一次初始化的數(shù)據(jù)。
一、延時加載主要應用的場景:
- 數(shù)據(jù)層(ADO.NET或Entity Framework等ORM,Java里面的Hibernate也用到了這種技術)
- 反射(加載assemblier,type,MEF)
- 緩存對象,領域實體
- 單例模式
二、簡單用法
如下:其中IsValueCreated屬相顯示其是否被創(chuàng)建。
static void Main(string[] args)
{
Lazy lazyBig = new Lazy();
Console.WriteLine("對象是否創(chuàng)建" + lazyBig.IsValueCreated);
lazyBig.Value.Test();
Console.WriteLine("對象是否創(chuàng)建" + lazyBig.IsValueCreated);
}
class Big {
public Big() { }
public void Test() {
Console.WriteLine("Test....");
}
} //結果如下: //對象是否創(chuàng)建False //Test.... //對象是否創(chuàng)建True
由此可見,根據(jù)lazy創(chuàng)建的對象,只有當?shù)谝淮问褂玫剿鼤r才會初始化.
另,lazy可使用委托來創(chuàng)建。
static void Main(string[] args)
{
Lazy lazyBig = new Lazy( () => new Big(100) );
lazyBig.Value.Test();
}
class Big {
public Big(int id) { this.ID = id; }
public int ID { get; set; }
public void Test()
{
Console.WriteLine("ID = " + ID.ToString());
}
}
原文鏈接:https://www.cnblogs.com/springsnow/p/11490512.html
相關推薦
- 2022-03-16 Docker安裝Nginx問題及錯誤分析_docker
- 2022-07-15 python中的字符串占位符的"{0:2}"_python
- 2022-04-03 Python實現(xiàn)對相同數(shù)據(jù)分箱的小技巧分享_python
- 2023-02-12 Jupyter?notebook如何實現(xiàn)打開數(shù)據(jù)集_python
- 2021-11-05 一文搞懂Golang?時間和日期相關函數(shù)_Golang
- 2022-07-02 Pandas?如何處理DataFrame中的inf值_python
- 2022-12-08 C語言如何實現(xiàn)成績等級判別_C 語言
- 2024-01-28 ThreadLocal,提供線程局部變量
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學習環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結構-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支