JSP数据提交到SQL中的空格问题
时间:2008-06-07 05:35:06
来源:论坛整理 作者: 编辑:chinaitzhe
当确认注册控件上的信息提交到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,空格,问题,
上一篇:请问在JSP中怎样传两个参数
下一篇:下面没有链接了











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