ExecuteScalar这个方法是从数据库中检索单个值返回值是object类型,必须用与它在数据库里存放的类型相同类型或者可以转换成的类型, 比如数据是nchar类型值为 "123" 就可以用(int)ExecuteScalar(), 如果数据是nchar类型值为 ""就不能用(int)ExecuteScalar(),就得写string result = ExecuteScalar().ToString ExecuteScalar 的规则就是,返回第一列,第一行的数据。如果第一列第一行不为空,那么ExecuteScalar就直接对应的DotNet的值。如果有第一行,但是第一列为空,那么返回的是 DBNull 。如果一行都没有,那么ExecuteScalar就返回null 规则就是这样的。这里容易犯的一个错误是,把ExecuteScalar返回DBNull与null的情况混淆,例如: string username=cmd.ExecuteScalar().ToString(); 除非你认为cmd执行后,肯定至少有一行数据,否则这里就会出错。