分类标签归档:CSharp

Asp.Net 中的异步死锁


首先大概介绍下asyncawait这两个关键字。
在.Net 4.5中,微软为了方便异步编程提供了asyncawait这两个关键字,使用他们,可以使我们很方便的实现自己的异步代码,而不用太去关心其内部原理。那么他们的主要作用使什么呢? async关键字加在方法的声明上,他的主要目的使为了使方法内部的await关键字生效。而方法的返回值也一般是Task或者Task<T>类型。这些Task类型一般相当于是future,用来在异步方法结束时通知主程序。如下面示例代码:

public async Task DoSomethingAsync()
{
    int ...

Read more

dotnet命令整理


基本格式:

dotnet [command] [arguments] [--additional-deps] [--additionalprobingpath] [-d|--diagnostics] [--fx-version] [-h|--help] [--info] [--roll-forward-on-no-candidate-fx] [-v|--verbose] [--version]

选项说明:
--additionaldeps <PATH>
其他路径deps.json文件。
--additionalprobingpath <PATH...

Read more

SqlServer使用表值参数批量插入更新数据


首先,创建自定义表类型:

CREATE TYPE BulkUdt AS TABLE(
Id int,
Name NVARCHAR(10)
)

然后是使用方式:

private static System.Data.DataTable GetTestTable()
{
    System.Data.DataTable dt = new System.Data.DataTable();
    dt.Columns.Add("Id");
    dt.Columns.Add("Name");
    for (int...

Read more

为mvc添加全局过滤器实现Response重写


我们公司的网站都是使用的是mvc框架,最近有这样的需求.因为之前的一些东西在开始开发的时候写死了.比如静态资源地址或者别的站点的地址.但是最近改版的时候需要重新配置地址.如果全局搜索修改地址的话工作量太大.于是想着是否可以使用全局过滤器来重写Response流来实现.下面给出解决方案. 具体就是重写ActionFilterAttribute.然后为Response.Filter重置为我们实现了我们业务需要的Filter. 首先创建过滤器.如下:

public class RewriteHttpsFilterAttribute : ActionFilterAttribute
   {
  ...

Read more

禁止在 .NET Framework 中执行用户代码。启用 "clr enabled" 配置选项 解决办法


今天遇到这么一个问题,当一次性执行多条SQL语句的时候报错, 出现如下问题 >"消息 6263,级别 16,状态 1,第 1 行 禁止在 .NET Framework 中执行用户代码。启用 "clr enabled" 配置选项。"

解决办法:

use datebase;
EXEC sp_configure 'clr enabled', 1
 go
 RECONFIGURE
 go
EXEC sp_configure 'clr enabled'
 go

Read more