sql语句字段+@是什么意思?

Metreus 2009-08-04 11:45:56

if (!BranchId.Equals(""))
{
sql += " and BranchId like '%" + @BranchId + "%'";
}

like 后面直接加BranchId不就行了么?
前面为什么要加@呢?
加上是什么意思啊?


如果加上了,那下面还用不用写这一句了呢?
 SqlParameter[] sp = { 
new SqlParameter("@BranchName",BranchId)
...全文
1671 7 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
missukiss02 2009-08-05
  • 打赏
  • 举报
回复
意思是变量
yuanchangyuan2125 2009-08-05
  • 打赏
  • 举报
回复
if (!BranchId.Equals(""))
{
sql += " and BranchId like '%" + @BranchId + "%'";
}

like '%" + @BranchId + "%'"; 是变量 ,加上@好像没什么用吧
@加在 sqlparmenter 转义字符
yuanchangyuan2125 2009-08-05
  • 打赏
  • 举报
回复
转义字符
杰子 2009-08-05
  • 打赏
  • 举报
回复
1.限定字符串
用 @ 符号加在字符串前面表示其中的转义字符“不”被处理。
如果我们写一个文件的路径,例如"D:\文本文件"路径下的text.txt文件,不加@符号的话写法如下:

string fileName = "D:\\文本文件\\text.txt";
如果使用@符号就会比较简单:

string fileName = @"D:\文本文件\text.txt";
2.让字符串跨行
有时候一个字符串写在一行中会很长(比如SQL语句),不使用@符号,一种写法是这样的:


string strSQL = "SELECT * FROM HumanResources.Employee AS e"
+ " INNER JOIN Person.Contact AS c"
+ " ON e.ContactID = c.ContactID"
+ " ORDER BY c.LastName";
加上@符号后就可以直接换行了:

string strSQL = @"SELECT * FROM HumanResources.Employee AS e
INNER JOIN Person.Contact AS c
ON e.ContactID = c.ContactID
ORDER BY c.LastName";
3.在标识符中的用法
C#是不允许关键字作为标识符(类名、变量名、方法名、表空间名等)使用的,但如果加上@之后就可以了,例如:

namespace @namespace
{
class @class
{
public static void @static(int @int)
{
if (@int > 0)
{
System.Console.WriteLine("Positive Integer");
}
else if (@int == 0)
{
System.Console.WriteLine("Zero");
}
else
{
System.Console.WriteLine("Negative Integer");
}
}
}
}
wtboy 2009-08-05
  • 打赏
  • 举报
回复
关注中。。。。
chenqi747 2009-08-05
  • 打赏
  • 举报
回复
e .
cyhcyhhychyc 2009-08-04
  • 打赏
  • 举报
回复
@加在变量前面可以不要处理那些引号,表示后面接的是变量,不能当成字符串

62,244

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧