考试辅导

名师推荐

试听名师的课 查看所有名师

计算机等级考试辅导:带参数的sql和不带参数的sql区别 发布时间:2010-07-10 17:26 来源:互联网

  带参数的sql语句,在数据库端,执行的是
  exec sp_executesql
  eg:
  exec sp_executesql N'insert into LCS_Sys_Model ([Model_GUID],[Model_Name],[Model_Desp],[Model_IsSys]) values ( @Model_GUID,@Model_Name,@Model_Desp,@Model_IsSys)', N'@Model_GUID uniqueidentifier,@Model_Name nvarchar(50),@Model_Desp nvarchar(500),@Model_IsSys bit', @Model_GUID = 'F3CD1369-58C0-4A1F-AF88-05FCF734E079', @Model_Name = N'测试实体模型', @Model_Desp = N'实体模型描述', @Model_IsSys = 0
  没有带值的sql语句。其执行是直接的sql语句。
  insert into lcs_Sys_Model ([Model_GUID],[Model_Name],[Model_Desp],[Model_IsSys]) values ( 'F3CD1369-58C0-4A1F-AF88-05FCF734E079','name','desp',1 )
  看上面的执行代码,你会不会认为是下面的高效啊?说实话我也没有仔细测试过。可是据我所知,sqlserver能够缓存参数信息和sql编译后的信息,第一句带参 数的sql因为前面一部是不变的(红色部分)。所以能够缓存起来(就像执行存储过程一样)。而下面的一句sql。因为value后面的值总是不固定,因此 sqlserver总是认为是不同的sql语句。因此每次都要重新编译生成。
  以上结论来源于下面的测试代码。
  http://space.cnblogs.com/question/2692/
  System.Data.SqlClient.SqlParameter[] parameters = {
  new SqlParameter("@Model_GUID", SqlDbType.UniqueIdentifier),
  new SqlParameter("@Model_Name", SqlDbType.NVarChar,50),
  new SqlParameter("@Model_Desp", SqlDbType.NVarChar,500),
  new SqlParameter("@Model_IsSys", SqlDbType.Bit)
  };
  parameters[0].Value = new Guid("F3CD1369-58C0-4A1F-AF88-05FCF734E079");
  parameters.Value = "测试实体模型";
  parameters.Value = "实体模型描述";
  parameters.Value = false;
  string connStr = @"Integrated Security=SSPI;Persist Security Info=False;Initial Catalog=officially;Data Source=LCSNB"SQL2K";
  string cmdStr = "insert into LCS_Sys_Model ([Model_GUID],[Model_Name],[Model_Desp],[Model_IsSys]) values ( @Model_GUID,@Model_Name,@Model_Desp,@Model_IsSys)";
  System.Data.SqlClient.SqlConnection conn = new System.Data.SqlClient.SqlConnection(connStr);
  System.Data.SqlClient.SqlCommand cmd = new System.Data.SqlClient.SqlCommand(cmdStr);
  cmd.Connection = conn;
  foreach (var item in parameters)
  {
  cmd.Parameters.Add(item);
  }

 

 

第一考试网友情提示:如果您遇到任何疑问,请登录第一考试网考试辅导频道或添加qq:,第一考试网以“为考友服务”为宗旨,秉承“快乐学习,轻松考试!”的理念,旨在为广大考友打造一个良好、温馨的学习与交流平台,欢迎持续关注。以上是小编为大家推荐的《计算机等级考试辅导:带参数的sql和不带参数的sql区别》相关信息。

编辑推荐

计算机等级考试辅导:SQL中JOB的运行状态

计算机等级考试辅导:SQLSERVER2005的引用

三级:把数据导入不同的表空间

2009年三级信息管理技术辅导:战略数据规划

教你三种方法卸载Windows7SP1Beta