注意ADO。NET中数据查询语句中的符号格式(c#实现)

王朝c#·作者佚名  2006-01-10
窄屏简体版  字體: |||超大  

注意ADO。NET中数据查询语句中的符号格式

1、通配符的使用

在ADO。NET中允许使用通配符进行数据查询。如下面语句查询表中EmployeeID以A开头的所有数据

Select EmployeeID,EmployName,Tel,Salary .....where EmployeeID='A%';

ADO。NET允许在字符串的开头或结尾使用%或*通配符。如下面语句查询表中所有单号尾为S的单据

Select productcode,productname,productsum,productprice ........where ordercode='%S'

ADO.NET不允许使用单独的符号如"?","-"等

2、分隔符的使用

a.引号

要注意ADO.NET中单引号的使用,例如在查询搜索用户姓名时,用户可能会查找姓名为K'Leey的数据,此时,数据查询语句将变为

name='K'Leey'

在查询时,出现单引号时,应将之替换为两个单引号,即name='K''Leey',我们在实际操作中,当数据查询语句中出现单引号时,可以使用String类的Replace方法进行替换将“'”换成“''”,如

condition = "name='"+tempname.Replace("'","''")+"'"

b.日期

可以使用#符号来处理ADO.NET中涉及日期格式的查询,如下示例

condition = "endDate<#2005/09/07# and endDate>#2005/08/07#"

c.列分隔符

当数据表中的某列由于某些原因含有列分隔符时,如sale order,可以使用[]将此列区分开来,如下示例

condition = "[sale order] = S845647"

此种情况下,如果数据列中已含有列分隔符做为列名的一部分时sale] order[,需要在列分隔符结束部分]前加入\符号,即

condition = "[sale\] order[] = S845647"

如果在C#中来处理这种ADO.NET操作时,需要注意符号转义问题,示例将变为

condition = "[sale\\] order[] = S845647"

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航