今天碰到一个substring的问题, 是双字节引起的.
sqlserver的substring(str, start ,length) 和 Oracle的 substr(str, start, length) 功能几乎完全相同. 要注意的是他们都是根据当前的字符集来计算字符串长度.
如 str = 'Iam中国人' 则 substring(str,3,2) 在中文数据库下返回"m中", 但在英文数据库下返回从m开始的两个字节.
所以如果想要根据字节来取数据,则要想别的办法.
oracle 很简单,可以使用substrb
sqlserver则没有相应的函数, 只能先把str转成 varbinary类型,然后再用substring.
sqlserver的substring(str, start ,length) 和 Oracle的 substr(str, start, length) 功能几乎完全相同. 要注意的是他们都是根据当前的字符集来计算字符串长度.
如 str = 'Iam中国人' 则 substring(str,3,2) 在中文数据库下返回"m中", 但在英文数据库下返回从m开始的两个字节.
所以如果想要根据字节来取数据,则要想别的办法.
oracle 很简单,可以使用substrb
sqlserver则没有相应的函数, 只能先把str转成 varbinary类型,然后再用substring.
博客主要讲述了SQL Server和Oracle中字符串截取函数的问题。SQL Server的substring和Oracle的substr功能相似,都按当前字符集计算字符串长度。以'Iam中国人'为例,不同字符集下截取结果不同。若要按字节取数据,Oracle可用substrb,SQL Server则需先转varbinary类型再用substring。
1005

被折叠的 条评论
为什么被折叠?



