JSP数据提交到SQL中的空格问题

时间:2008-06-07 05:35:06   来源:论坛整理  作者:  编辑:chinaitzhe
今天写了一个简单的JSP注册页面,页面上使用了TextField和Password控件,开发环境MyEclipse
当确认注册控件上的信息提交到SQL2000中时查看注册的内容时发现所有数据后面都有若干空格,加载一起的长度正好是我设置数据类型varchar的上限值
正常情况下在SQL数据表中的数据类型中设置了varchar可以自适应输入的字符长度,但是这个居然还是有空格,请各位指点下,谢谢!
网友回复:varchar 是可变长度的数据类型。比列的长度小的值,不会按照列的长度在其右边填补。当创建列时,假如 ANSI_PADDING 选项设为 OFF,则所有存储在列中的字符值的尾随空格都将被截断。当创建列时,假如 ANSI_PADDING 设为 ON,则尾随空格不被截断。
网友回复:char 和 varchar
固定长度 (char) 或可变长度 (varchar) 字符数据类型。

char[(n)]

长度为 n 个字节的固定长度且非 Unicode 的字符数据。n 必须是一个介于 1 和 8,000 之间的数值。存储大小为 n 个字节。char 在 SQL-92 中的同义词为 character。

varchar[(n)]

长度为 n 个字节的可变长度且非 Unicode 的字符数据。n 必须是一个介于 1 和 8,000 之间的数值。存储大小为输入数据的字节的实际长度,而不是 n 个字节。所输入的数据字符长度可以为零。varchar 在 SQL-92 中的同义词为 char varying 或 character varying。

注释
假如没有在数据定义或变量声明语句中指定 n,则默认长度为 1。假如没有使用 CAST 函数指定 n,则默认长度为 30。

将为使用 char 或 varchar 的对象被指派数据库的默认排序规则,除非用 COLLATE 子句另外指派了特定的排序规则。该排序规则控制用于存储字符数据的代码页。

支持多语言的站点应考虑使用 Unicode nchar 或 nvarchar 数据类型以尽量减少字符转换问题。假如使用 char 或 varchar:

假如希望列中的数据值大小接近一致,请使用 char。


假如希望列中的数据值大小显著不同,请使用 varchar。
假如执行 CREATE TABLE 或 ALTER TABLE 时 SET ANSI_PADDING 为 OFF,则一个定义为 NULL 的 char 列将被作为 varchar 处理。

当排序规则代码页使用双字节字符时,存储大小仍然为 n 个字节。根据字符串的不同,n 个字节的存储大小可能小于 n 个字符。
网友回复:谢谢这位朋友,我把SQL语句前加上"SET ANSI_PADDING OFF"就可以解决问题了
关键字:JSP,数据,提交,SQL,空格,问题,

相关文章

文章评论

共有 0 位网友发表了评论 此处只显示部分留言 点击查看完整评论页面