在进行URL传值时,有些特定字符无法直接传输,可以进行间接传输。具体如下:
url中可能用到的特殊字符及在url中的经过编码后的值:(此表格借鉴)
字符 |
|
特殊字符的含义 |
URL编码 |
# |
|
用来标志特定的文档位置 |
%23 |
% |
|
对特殊字符进行编码 |
%25 |
& |
|
分隔不同的变量值对 |
%26 |
+ |
|
在变量值中表示空格 |
%2B |
/ |
|
表示目录路径 |
%2F |
\ |
|
表示目录路径 |
%5C |
= |
|
用来连接键和值 |
%3D |
? |
|
表示查询字符串的开始 |
%3F |
空格 |
|
空格 |
%20 |
. |
|
句号 |
%2E |
: |
|
冒号 |
%3A |
假如你的参数是上方的url编码值,比如%23、%25这些,那么后台接收到的值,就是其对应的字符。
比如传值"%23",接收到的值就是"#"。
所以这点需要注意了,有可能输入特殊url编码值得参数,还是别这样传值了。
令求大神有无其他解决办法?请赐教!
替换
select REPLACE('夏晶是个大坏蛋','坏','好')
反转
select REVERSE('夏晶是个大坏蛋')
取值
select SUBSTRING('夏晶才不是个大坏蛋呢,我爱夏晶',12,4)
从第12位开始取值,取4位
string sqlQuery = "select c.CustomerId,c.CommunityId,c.BuildingId,c.UnitId,com.CommunityName,com.StationId,b.BuildingName,m.MeterId,m.MeterAddr,u.UnitName+'-'+convert(varchar(20),c.FloorNo)+'-'+c.RoomNo as MeterName from basCustomer as c left join basCommunity as com on c.CommunityId=com.CommunityId left join basBuilding as b on c.BuildingId=b.BuildingId left join basUnit as u on c.UnitId=u.UnitId join dvMeter as m on(SUBSTRING(CONVERT(VARBINARY(50), com.StationId),4,1)+SUBSTRING(CONVERT(VARBINARY(50), com.StationId),3,1)+SUBSTRING(CONVERT(VARBINARY(50), c.CommunityId),4,1)+SUBSTRING(CONVERT(VARBINARY(50), c.CommunityId),3,1)+SUBSTRING(CONVERT(VARBINARY(50), c.BuildingId),4,1)+SUBSTRING(CONVERT(VARBINARY(50), c.BuildingId),3,1)+SUBSTRING(CONVERT(VARBINARY(50), c.BuildingId),2,1)+SUBSTRING(CONVERT(VARBINARY(50), c.UnitId),4,1)+SUBSTRING(CONVERT(VARBINARY(50), c.UnitId),3,1)+SUBSTRING(CONVERT(VARBINARY(50), c.UnitId),2,1)+SUBSTRING(CONVERT(VARBINARY(50), c.UnitId),1,1)+SUBSTRING(CONVERT(VARBINARY(50), c.CustomerId),4,1)+SUBSTRING(CONVERT(VARBINARY(50), c.CustomerId),3,1)+SUBSTRING(CONVERT(VARBINARY(50), c.CustomerId),2,1)+SUBSTRING(CONVERT(VARBINARY(50), c.CustomerId),1,1))=m.LocationCode where b.BuildingName=" + BuildingName;