網(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也用到了這種技術(shù))
- 反射(加載assemblier,type,MEF)
- 緩存對象,領域?qū)嶓w
- 單例模式
二、簡單用法
如下:其中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....");
}
} //結(jié)果如下: //對象是否創(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
相關(guān)推薦
- 2022-12-06 Python如何查看并打印matplotlib中所有的colormap(cmap)類型_python
- 2022-08-16 python中的屬性管理機制詳解_python
- 2022-04-28 shell?腳本中獲取命令的輸出的實現(xiàn)示例_linux shell
- 2022-09-21 python?Flask框架之HTTP請求詳解_python
- 2022-07-17 SQL?Server中鎖的用法_MsSql
- 2022-08-22 C++動態(tài)規(guī)劃計算最大子數(shù)組_C 語言
- 2022-06-26 ASP.NET?Core中引用OpenAPI服務的添加示例_實用技巧
- 2022-09-22 git只提交部分修改的文件(提交指定文件)
- 最近更新
-
- 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之基于方法配置權(quán)
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支