JSp sql 中的引号问题

2024-11-16 02:50:42
推荐回答(1个)
回答(1):

先来看一个最简单的SQL语句
Insert Into users(username) values("小王")
大家来看一下,这是一个标准的SQL语句,因为username是文本型字段,所以字段值两边要加双引号,表示小王是一个字符串。
(2)可是在ASP中,我们通常这样写
strSql="Insert Into users(username) values('小王')"
此时,前后的双引号表示中间是一个字符串。而小王两边的单引号是因为发生了引号嵌套,
所以内层引号该为了单引号。
(3)实际插入时,因为小王通常是从表单中获取的变量,不过因为变量不能直接写入字符串,必须通过连接符&和字符串连接在一起,所以要写成如下形式:
myusername=Request.Form("username")
……
strSql="Insert Into users(username) values('" & myusername & "')"
很多人此时就糊涂了,为什么其中又有单引号,又有双引号啊。简单的看上面的式子,其实是由如下三部分组成的:
字符串常数:"Insert Into users(username) values('"
字符串变量:myusername
字符串常数:"')"
直接理解上面的式子可能比较困难,现在悉迅我们变量myusername的值代入就能看清楚了。
假如myusername="小王",代入:
strSql="弊陆世Insert Into users(username) values('" & "小王" & "')"
然后依次执行其中的连接运算符,结果为:
strSql="Insert Into users(username) values('小王')"租肢
这就是(2)中提到的正确的SQL语句。
到此就能看清楚了: