刚才遇到了一个奇怪的问题
我从数据库中读取数据(假设该数据为a)为下拉框中的默认选中项
可是默认选中项始终为该下拉框的初始值,也就是a没有被设置为默认项后来我怀疑是table中a这一列可能被加' '了,就输出了一下a所赋予的变量
发现输出的结果真的是'a '于是我把table中a列中的' '去掉了
但当运行程序后table中的该列就又变为'a '了
我又改了好几次都是又变回来了没办法,我只好在程序获取结果时加了一个.trim()方法
虽然这样可以解决,可是我数据库中的值始终是'a ' 是怎么回事呢?
是我程序的问题?
还是sql的问题呢?(我用的sql2000)拜谢~~
我从数据库中读取数据(假设该数据为a)为下拉框中的默认选中项
可是默认选中项始终为该下拉框的初始值,也就是a没有被设置为默认项后来我怀疑是table中a这一列可能被加' '了,就输出了一下a所赋予的变量
发现输出的结果真的是'a '于是我把table中a列中的' '去掉了
但当运行程序后table中的该列就又变为'a '了
我又改了好几次都是又变回来了没办法,我只好在程序获取结果时加了一个.trim()方法
虽然这样可以解决,可是我数据库中的值始终是'a ' 是怎么回事呢?
是我程序的问题?
还是sql的问题呢?(我用的sql2000)拜谢~~
固定长度 (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 个字符。
char位數不夠會自動補足空格的
insert into tb select 'a'
select '+'+id+'+' from tb
alter table tb alter column id varchar(10)
insert into tb select 'b'
select '+'+id+'+' from tb+a +
+b+
insert into tb select 'a'
select '+'+id+'+' from tb
alter table tb alter column id varchar(10)
insert into tb select 'b'
select '+'+id+'+' from tb
update tb set id=rtrim(id)
select '+'+id+'+' from tb+a+
+b+