NicPetShop 介绍并提供下载
作者:靓仔 日期:2008-03-24
新手制作网页常用手册大全 - 推荐
作者:靓仔 日期:2008-02-03
ExecuteReader 与 OUTPUT 参数问题
作者:靓仔 日期:2008-05-07
今天在将 NicPetShop 的 DAL 添加存储过程控制后,测试到 SqlParameter 与 ExecuteReader 的问题。
当 SqlParameter.Direction 设置成 ParameterDirection.Output,将 SqlParameter 添加到 SqlCommand.Parameters 中,最后执行 SqlCommand.ExecuteReader 后无法得到返回的 @a 值 10,将 ExecuteReader 改成 ExecuteNoneQuery 后没有这个问题,为什么呢?
以前少用存储过程开发,一直都是用 sql,个人感觉 sql 比 sp 灵活得多。
在网上找了找相关资料,ExecuteReader 的链接没有关闭前无法得到需要返回的参数值,测试了一下后果真如此。
存储过程:
create proc dbo.test
(
@a int output
)
as
set @a = 10
测试代码:
SqlParameter parm = new SqlParameter("@a", System.Data.SqlDbType.Int);
parm.Direction = System.Data.ParameterDirection.Output;
SqlCommand cmd = new SqlCommand(ConnectionManager.GetConnection());
cmd.Parameters.Add(parm);
cmd.Connection.Open();
using (IDataReader dr = cmd.ExecuteReader(CommandBehavior.CloseConnection))
{
Response.Write(parm.Value + ","); //为空
cmd.Connection.Close();
Response.Write(parm.Value + ","); //10
}我的程序所有地方都是用 dr.Dispose 来关闭 Connection 的。但 dr.Dispose 虽然可以关闭 Connection,但同时它也将自己毁消了,最后还是得不到 Parm.Value。
暂时找不到更好的方法,只有先把之前的改一改。
27/3 2:02 am 发表:
最好发现是 SqlHelper.cs 里的 cmd.Parameters.Clear(); 造成

public static IDataReader ExecuteReader(SqlConnection conn, CommandType cmdType, string cmdText, params SqlParameter[] cmdParms)
{
SqlCommand cmd = new SqlCommand();
PrepareCommand(cmd, conn, cmdType, cmdText, cmdParms);
SqlDataReader dr = null;
Exception ex = Lib.Trys(delegate()
{
if (cmd.Connection.State != ConnectionState.Open) cmd.Connection.Open();
try
{
dr = cmd.ExecuteReader(CommandBehavior.CloseConnection);
} catch
{
if (!Lib.IsWeb) Thread.CurrentThread.Join(1000);
throw;
}
}, Lib.IsWeb ? 1 : 60);
LoggerException(cmd, ex);
return dr;
}

static void LoggerException(SqlCommand cmd, Exception e)
{
if (e == null)
{
cmd.Parameters.Clear(); //小小的错误啊
return;
}
string log = "〓〓〓〓〓〓〓〓〓〓〓〓〓〓〓" + cmd.CommandText + "\r\n";
foreach (SqlParameter parm in cmd.Parameters)
{
log += Lib.PadRight(parm.ParameterName, 20) + " = " + Lib.PadRight(parm.Value == null ? "NULL" : parm.Value, 20) + "\r\n";
}
Log.Fatal(log + "\r\n\r\n", e);
cmd.Parameters.Clear();
cmd.Connection.Close();
throw e;
}Tags: NicPetShop
对 ADSL 进行拨号
作者:靓仔 日期:2008-03-25
[摘抄] JS关闭窗口, IE7 不弹出提示的代码
作者:靓仔 日期:2008-03-22
程序代码window.open('','_top');
window.top.close();
[录像] 附我的开发模式实战
作者:靓仔 日期:2008-03-20
[原]右眼跳灾,当破财消灾
作者:靓仔 日期:2008-03-08
早上9点起来,准备出门的时间右眼小跳了几下,跟着就去了公交站,上车后发现牛仔裤内手机又不见了。
已经是第二次了,05年7月买的 nokia n72 于 05年11月在大沙头上 543 路车时被偷,心情失落了好一阵。
发现今天的心态还算好了,换一种心态,破财消灾。
今次,07年11月买的 nokia n73 于 08年3月8日在敦和站上 139 路车时被偷,还算明白,就像吃饭一样,不会失落了。
接下来我要做什么?
[转]小心使用@@identity
作者:靓仔 日期:2008-03-03
但有一点是需要注意的,@@identity 返回的是最后的标识符,所以,要想正确的返回插入后的标识符,那么就必须保证,你想要的结果是最后的标识符,否则就会隐藏bug。
仔细阅读 @@identity 的注释:
注释
在一条 Insert、Select INTO 或大容量复制语句完成后,@@IDENTITY 中包含此语句产生的最后的标识值。若此语句没有影响任何有标识列的表,则 @@IDENTITY 返回 NULL。若插入了多个行,则会产生多个标识值,@@IDENTITY 返回最后产生的标识值。如果此语句激发一个或多个执行产生标识值的插入操作的触发器,则语句执行后立即调用 @@IDENTITY 将返回由触发器产生的最后的标识值。若 Insert 或 Select INTO 语句失败或大容量复制失败,或事务被回滚,则 @@IDENTITY 值不会还原为以前的设置。
在返回插入到表的 @@IDENTITY 列的最后一个值方面,@@IDENTITY、SCOPE_IDENTITY 和 IDENT_CURRENT 函数类似。
@@IDENTITY 和 SCOPE_IDENTITY 将返回在当前会话的所有表中生成的最后一个标识值。但是,SCOPE_IDENTITY 只在当前作用域内返回值,而 @@IDENTITY 不限于特定的作用域。
[转].NET牛人应该知道些什么
作者:靓仔 日期:2008-03-02
原文地址:http://www.hanselman.com/blog/WhatGreatNETDevelopersOughtToKnowMoreNETInterviewQuestions.aspx 作者:Scott Hanselman
译者:Tony Qu
前些日子我发了一份ASP.NET面试题 清单. 有一些访客比较保守,觉得我是没事找事,里面都是些很琐碎的问题。剩下的人则说“蛮不错的,我得去看一看其中的一些问题” 我更喜欢后者的回复,我觉得后者才是正确的态度。
当然我并不想把.NET软件开发概括为一些简单的小问题,我只是想让大家多思考。我相信一个真正优秀的ASP.NET(及WinForm)开发人员应该不仅仅会拖放控件到设计器中,也应该掌握更多的东西。一个优秀的赛车比赛选手很了解他自己的坐驾,他知道哪些可以做?哪些不能做?
所以我准备了另外一份清单——一份扩展的清单,供你使用。这是我上个星期在从博伊西去波特兰的路上写在一块板上的,并且我也考虑到了那些觉得我的清单过于琐碎的意见,试图把这个清单按节管理。如果你从来没有深入ASP.NET,你肯定不会知道所有ASP.NET问题的答案。如果你是一个独立顾问,你可能从来没有遇到过这些概念。但在我呆在科林斯的这4年中,这些问题我都遇到过。因此,是否全面理解这些问题也许与你是不是一个优秀的开发者没有关系,但在遇到问题时它的确可以帮你节省不少时间。
.NET牛人应该知道些什么?
任何一个使用.NET的人
- 描述线程与进程的区别?
- 什么是Windows服务,它的生命周期与标准的EXE程序有什么不同
- Windows上的单个进程所能访问的最大内存量是多少?它与系统的最大虚拟内存一样吗?这对于系统设计有什么影响?
- EXE和DLL之间的区别是什么?
- 什么是强类型,什么是弱类型?哪种更好些?为什么?
- PID是什么?在做系统的故障排除时如何使用它?
- 单个TCP/IP端口上能够侦听多少个进程?
- 什么是GAC?它解决了什么问题?
中级.NET开发人员
- 阐述面向接口、面向对象、面向方面编程的区别
- 什么是Interface?它与Class有什么区别?
- 什么是反射?
- 使用ASMX的XML Web服务与使用SOAP的.NET Remoting的区别?
- 类型系统是由XMLSchema表示的吗?CLS是XMLSchema表示的吗?
- 从概念上阐述前期绑定(early-binding)和后期绑定(late-binding)的区别?
- 调用Assembly.Load算静态引用还是动态引用?
- 何时使用Assembly.LoadFrom?何时使用Assembly.LoadFile?
- 什么叫Assembly Qualified Name?它是一个文件名吗?它有什么不同?
- Assembly.Load("foo.dll"); 这句话是否正确?
- 做强签名的assembly与不做强签名的assembly有什么不同?
- DateTime是否可以为null?
- 什么叫JIT?什么是NGEN?它们分别有什么限制和好处?
- .NET CLR中一代的垃圾收集器是如何管理对象的生命周期的?什么叫非确定性终结?
- Finalize()和Dispose()之间的区别?
- using() 语法有用吗?什么是IDisposable?它是如何实现确定性终结的。
- tasklist /m "mscor*" 这句命令是干嘛的?
- in-proc和out-of-proc的区别
- .NET里的哪一项技术能够实现out-of-proc通讯?
- 当你在ASP.NET中运行一个组件时,它在Windows XP, Windows 2000, Windows 2003上分别跑在哪个进程里面?
高级开发人员/架构师
- DateTime.Parse(myString); 这行代码有什么问题?
- PDB是什么东西? 在调试中它应该放在哪里?
- 什么叫圈复杂度(cyclomatic complexity)?为什么它很重要?
- 写一个标准的lock(),在访问变量的前后创建临界区,要有"双重检查",
- 什么叫FullTrust?放入GAC的assembly是否是FullTrust的?
- 代码加上需要安全权限的特性有什么好处?
- gacutil /l | find /i "Corillian" 这句命令的作用是什么?
- sn -t foo.dll 这句命令是干嘛的?
- DCOM需要防火墙打开哪些端口?端口135是干嘛用的?
- 对比OOP和SOA,它们的目的分别是什么?
- XmlSerializer是如何工作的?使用这个类的进程需要什么ACL权限?
- 为什么不提倡catch(Exception)?
- Debug.Write和Trace.Write有什么不同?何时应该使用哪一个?
- Debug Build和Release Build的区别,是否会有明显的速度变化?请说明理由。
- JIT是以assembly为单位发生还是以方法为单位发生?这对于工作区有何影响?
- 对比抽象基类和接口的使用
- a.Equals(b)和a == b一样吗?
- 在对象比较中,对象一致和对象相等分别是指什么?
- 在.NET中如何实现深拷贝(deep copy)?
- 请解释一下IClonable
- 什么叫装箱?
- string是值类型还是引用类型?
- XmlSerializer使用的针对属性的模式有什么好处?解决了什么问题?
- 为什么不应该在.NET中使用out参数?它究竟好不好?
- 特性能够放到某个方法的参数上?如果可以,这有什么用?
C# 组件开发人员
- 什么时候使用override?什么时候使用new? 什么叫shadowing?
- 解释virtual、sealed、override和abstract的区别
- Foo.Bar, Version=2.0.205.0, Culture=neutral, PublicKeyToken=593777ae2d274679d 解释这个字符串每个部分的重要性和作用
- 解释public、protected、private和internal的区别
- 使用Primary Interop Assembly (PIA)有什么好处?
- NUnit是通过什么机制获知需要测试哪些方法的?
- catch(Exception e){throw e;}和catch(Exception e){throw;}的区别
- typeof(foo)和myFoo.GetType()的区别?
- public class c{ public c(string a) : this() {;}; public c() {;} } 解释第一个构造函数中发生了什么? 这个构造函数有什么用?
- this是干嘛用的?能够用在static方法中?
ASP.NET (UI)开发人员
- 阐述一个基于浏览器的Form POST如何变成一个服务器端的事件,如Button1_OnClick。
- 什么是PostBack?
- 什么是ViewState? 它是否被编码过? 是否被加密过?谁会使用ViewState?
- <machinekey>元素是干嘛用的?它用于哪两项ASP.NET技术?
- 说出ASP.NET 1.1中的3种Session State提供程序以及它们的优缺点?
- 什么叫Web Gardening? 在设计中如何使用它?
- 假设有一个ASP.NET应用程序,那么单独一个进程中允许多少应用程序对象?那两个进程呢?启用了Web Gardening的2个进程呢?这对设计有何影响?
- ASP.NET会重用多个请求之间的线程吗?是否每个HttpRequest都有自己的线程?你是否应该用ASP.NET的Thread Local存储?
- [ThreadStatic]属性在ASP.NET中有用吗?它有没有副作用?是好是坏?
- 如何使用HttpHandler简化现有的为.aspx页面提供验证图片的设计
- HttpModule订阅的是什么类型的事件? 这对于实现有何影响?如果不打算重新编译ASP.NE应用程序,应该怎么做?
- 说出表示任意一个终端(URL)的方式,以及ASP.NET中把请求路由到那个终点的方式
- 解释cookie的工作原理。给出一个滥用Cookie的例子。
- 解释HttpRequest.ValidateInput()的重要性?
- 哪些数据是通过HTTP Header传递的?
- 对比HTTP动词GET和POST? 什么是HEAD?
- 说出至少6个HTTP状态码以及它们的含义
- if-not-modified-since的工作原理是什么? 用ASP.NET如何实现它?
- 解释 <@OutputCache%>和如何使用VaryByParam、VaryByHeader.
- VaryByCustom是如何工作的?
- 如何通过q=? (除了q=5)来实现ASP.NET HTML输出缓冲和缓冲过期(比如http://localhost/page.aspx?q=5)?
XML开发人员
- XML命名空间的作用?
- 何时适合使用DOM?何时不适合?有没有尺度限制?
- 什么是WS-I基本配置?它重要在哪里?
- 写一个小XML文档,其中使用的是默认的命名空间,以及一个合法的(前缀)命名空间,其中要有分别属性这两个命名空间的元素
- 元素和特性的基本区别在哪里?
- 格式完好的XML和有效的XML有什么区别?
- .NET中如何验证XML?
- myXmlDocument.SelectNodes("//mynode"); 为什么这句代码不好?什么时候它是好的?
- 拉式解析(XmlReader)与事件读取器(Sax)的区别
- XPathDocument和XmlDocument的区别? 在何种情况下应该用哪一个?
- “XML片断”与“XML文档”有什么区别
- 什么叫格式规范的XML?
- XML InfoSet规范与Xml DOM有什么不同? InfoSet是要解决什么问题?
- 比较DTD和XSD,它们的相似点与区别分别是什么?哪个更好些?为什么?
- System.Xml支持DTD吗?如果支持,如何使用?
- XML Schema能够表示为对象图?对象图能够表示为XML Schema?






