预览模式: 普通 | 列表

NicPetShop 介绍并提供下载

ExecuteReader 与 OUTPUT 参数问题

今天在将 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

分类:.Net | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 26

对 ADSL 进行拨号

如果是直接在 windows 上拨号,请用下面代码,如果想让路由拨号,可以获取 http 包后,向路由器提效拨号的请求。


程序代码 程序代码
RASHelper.Connect("adsl");



程序代码 程序代码
using System;
using System.Runtime.InteropServices;

public class RASHelper {

查看更多...

分类:.Net | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 95
在IE7 下, 用window.close() 关闭一个窗口, IE7 总是会弹出一个提示, 问是否关闭这个窗口, 烦都烦死了, 可以让它不弹出提示的代码如下:

程序代码 程序代码
window.opener=null;
window.open('','_top');
window.top.close();


查看更多...

分类:JavaScript | 固定链接 | 评论: 1 | 引用: 0 | 查看次数: 81

[录像] 附我的开发模式实战


请直接下载吧:

MyPetShop.rar

27.2 MB (28,561,389 字节)
分类:.Net | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 196

[原]右眼跳灾,当破财消灾

  今天是个隆重的日子,三八妇女节,虽然不属于我的节日,在这里祝全国的妇女节日快乐。

  早上9点起来,准备出门的时间右眼小跳了几下,跟着就去了公交站,上车后发现牛仔裤内手机又不见了。
­
  已经是第二次了,05年7月买的 nokia n72 于 05年11月在大沙头上 543 路车时被偷,心情失落了好一阵。
­
  发现今天的心态还算好了,换一种心态,破财消灾。
­
  今次,07年11月买的 nokia n73 于 08年3月8日在敦和站上 139 路车时被偷,还算明白,就像吃饭一样,不会失落了。
­
  接下来我要做什么?

查看更多...

分类:Misc | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 109

[转]小心使用@@identity

@@identity 的作用是返回最后插入的标识值,所以有很多朋友使用它来获取插入数据后的标识符。
但有一点是需要注意的,@@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 不限于特定的作用域。

查看更多...

Tags: Database SQL T-SQL 数据库 identity

分类:Database | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 98

[转].NET牛人应该知道些什么

原文地址: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?
分类:Misc | 固定链接 | 评论: 0 | 引用: 0 | 查看次数: 104