我的VS2013中,用Ado.net给SQLParameter赋值的时候,当赋值null的时候,生成的sql语句是default

/// <summary>
        /// 增加一条数据
        /// </summary>
        public bool Add(Model.WechatDocuments model)
        {
            StringBuilder strSql=new StringBuilder();
            strSql.Append("insert into WechatDocuments(");
            strSql.Append("DocumentName,DocumentPath,DocumentFormatType,UploadBy,UploadDate,UploaderOpenId,BillNo,BillAmount,Reviewedby,ReviewedDate,ReviewedResult,ReviewedComment)");
            strSql.Append(" values (");
            strSql.Append("@DocumentName,@DocumentPath,@DocumentFormatType,@UploadBy,@UploadDate,@UploaderOpenId,@BillNo,@BillAmount,@Reviewedby,@ReviewedDate,@ReviewedResult,@ReviewedComment)");
            SqlParameter[] parameters = {
                    new SqlParameter("@DocumentName", SqlDbType.VarChar,500),
                    new SqlParameter("@DocumentPath", SqlDbType.VarChar,500),
                    new SqlParameter("@DocumentFormatType", SqlDbType.VarChar,20),
                    new SqlParameter("@UploadBy", SqlDbType.VarChar,100),
                    new SqlParameter("@UploadDate", SqlDbType.DateTime),
                    new SqlParameter("@UploaderOpenId", SqlDbType.VarChar,100),
                    new SqlParameter("@BillNo", SqlDbType.VarChar,100),
                    new SqlParameter("@BillAmount", SqlDbType.Float,8),
                    new SqlParameter("@Reviewedby", SqlDbType.VarChar,100),
                    new SqlParameter("@ReviewedDate", SqlDbType.DateTime),
                    new SqlParameter("@ReviewedResult", SqlDbType.Bit,1),
                    new SqlParameter("@ReviewedComment", SqlDbType.VarChar,500)};
            parameters[0].Value = model.DocumentName;
            parameters[1].Value = model.DocumentPath;
            parameters[2].Value = model.DocumentFormatType;
            parameters[3].Value = model.UploadBy??"";
            parameters[4].Value = model.UploadDate??Convert.ToDateTime("1970/01/01");
            parameters[5].Value = model.UploaderOpenId??"";
            parameters[6].Value = model.BillNo??"";
            parameters[7].Value = model.BillAmount??0;
            parameters[8].Value = model.Reviewedby??"";
            parameters[9].Value = model.ReviewedDate ?? Convert.ToDateTime("1970/01/01");
            parameters[10].Value = model.ReviewedResult;
            parameters[11].Value = model.ReviewedComment??"";

            return SQLServerHelper.ExcuteNonQuery(strSql.ToString(), CommandType.Text, parameters);
        }

exec sp_executesql N‘insert into WechatDocuments(DocumentName,DocumentPath,DocumentFormatType,UploadBy,UploadDate,UploaderOpenId,BillNo,BillAmount,Reviewedby,ReviewedDate,ReviewedResult,ReviewedComment) values (@DocumentName,@DocumentPath,@DocumentFormatType,@UploadBy,@UploadDate,@UploaderOpenId,@BillNo,@BillAmount,@Reviewedby,@ReviewedDate,@ReviewedResult,@ReviewedComment)‘,N‘@DocumentName varchar(500),@DocumentPath varchar(500),@DocumentFormatType varchar(20),@UploadBy varchar(100),@UploadDate datetime,@UploaderOpenId varchar(100),@BillNo varchar(100),@BillAmount float,@Reviewedby varchar(100),@ReviewedDate datetime,@ReviewedResult bit,@ReviewedComment varchar(500)‘,@DocumentName=‘20151216072318_2511.jpg‘,@DocumentPath=‘/UploadFiles/Bill/20151216072318_2511.jpg‘,@DocumentFormatType=default,@UploadBy=‘‘,@UploadDate=‘2015-12-16 07:23:29.107‘,@UploaderOpenId=‘‘,@BillNo=‘‘,@BillAmount=0,@Reviewedby=‘‘,@ReviewedDate=‘1970-01-01 00:00:00‘,@ReviewedResult=0,@ReviewedComment=‘‘

执行报错:

Msg 8178, Level 16, State 1, Line 0
The parameterized query ‘(@DocumentName varchar(500),@DocumentPath varchar(500),@Document‘ expects the parameter ‘@DocumentFormatType‘, which was not supplied.

把@DocumentFormatType=default改为@DocumentFormatType=null,就成功执行。在新添加一条数据的时候,某些字段是需要它为null的,不知道是我VS出问题了还是?

----------------------------------------------------------------------------------------------------

Error 19 The type ‘string‘ must be a non-nullable value type in order to use it as parameter ‘T‘ in the generic type or method ‘System.Nullable<T>

错误19字符型必须是非空值类型来使用它作为参数T的泛型类型或方法的系统。空<T>

时间: 2024-10-11 09:03:59

我的VS2013中,用Ado.net给SQLParameter赋值的时候,当赋值null的时候,生成的sql语句是default的相关文章

oracle问题:新建了一个PDM文件,建表后生成的sql语句中含有clustered

问题描述 为了在oracle中新增表,在PDM中建表,使用其生成的sql语句,但是建表不能成功,提示 ORA-00906: 缺失左括号 原因是多了clustered 关键字 情景重现 1. 新建一个pdm文件 2. 建表后预览sql 是有clustered 这个关键字的 3. 建表时报错 问题解决 调查发现数据库的问题,右键数据库属性 查看DBMS 发现是 SQL SERVER ! 解决办法就是切换DBMS: 点击确定 再次查看sql语句,一切正常.问题最终解决.

Entity Framewrok 7beta7中不同版本sql server自动生成分页sql语句的问题

在EF中,使用linq进行分页是很方便的,假如我们有一个EMP表,结构如下: public class Emp { [Key] public Guid No { get; set; } public int Age { get; set; } [Required] [StringLength(50)] public string Name { get; set; } } 如果我们进行分页的话,一般使用Skip和Take方法,这里一行最简单的代码如下: mContext.Emp.OrderBy(e

COMMENT方法 用于在生成的SQL语句中添加注释内容,

COMMENT方法 用于在生成的SQL语句中添加注释内容,例如: $this->comment('查询考试前十名分数') ->field('username,score') ->limit(10) ->order('score desc') ->select(); 复制代码 大理石平台知识 最终生成的SQL语句是: SELECT username,score FROM think_score ORDER BY score desc LIMIT 10 /* 查询考试前十名分数

Entity Framework中查看生成的SQL语句

using (Entities entities = new Entities()) { var query = from st in entities.ShiTi select st; ObjectQuery oq = query as ObjectQuery; string sql = oq.ToTraceString(); Console.WriteLine(sql); }

请问在 .NET Core 中如何让 Entity Framework Core 在日志中记录由 LINQ 生成的SQL语句?

using dotNET.Core; using Microsoft.Extensions.Logging; using System; using System.Collections.Generic; using System.Diagnostics; using System.Text; namespace dotNET.EFCoreRepository { /// <summary> /// ef 日志 /// </summary> public class EFLogge

mysql中查看ef或efcore生成的sql语句

http://www.solves.com.cn/it/sjk/MYSQL/2019-07-01/1336.html 涉及命令 1.开启general log模式 MySQL>set global general_log=on; 2.关闭general log模式 mysql>set global general_log=off; 3.设置log文件路径 mysql>set global general_log_file='xx/xx/xx.log'; 1.查看是否开启日志记录 show

EF中执行sql语句

EF原理 EF 会自动把 Where().OrderBy().Select()等这些编译成"表达式树(Expression Tree)",然后会把表达式树翻译成 SQL 语句去执行.(编译原理,AST)因此不是"把数据都取到内存中,然后使用集合的方法进行数据过滤",因此性能不会低.但是如果这个操作不能被翻译成 SQL 语句,则或者报错,或者被放到内存中操作,性能就会非常低 跟踪EF的查询Sql语句: DbContext 有一个 Database 属性,其中的 Log

机房收费系统中遇到的SQL语句问题

个人版机房收费系统正在进行中,遇到了几个有关SQL语句的问题. 1.sum函数的使用: 在结账部分,要求出某个表中某一列的和.在第一次机房系统中,我不知道sum函数的存在,很傻很天真地用循环一个一个往上加.下面以求所有卡中余额的和来说说sum函数怎么使,SQL语句为:select sum(cash)from T_Card.这个格式不是固定的,可以根据需求更改,比如求多列的和:select sum(列名1),sum(列名2)...from [表名] where....查询出来的结果只有一行,如果只

ORACLE 中 SQL语句优化

(1) 选择最有效率的表名顺序(只在基于规则的优化器中有效):  ORACLE的解析器按照从右到左的顺序处理FROM子句中的表名,FROM子句中写在最后的表(基础表 driving table)将被最先处理,在FROM子句中包含多个表的情况下,你必须选择记录条数最少的表作为基础表.如果有3个以上的表连接查询, 那就需要选择交叉表(intersection table)作为基础表, 交叉表是指那个被其他表所引用的表.    (2) WHERE子句中的连接顺序.:  ORACLE采用自下而上的顺序解