我需要(我认为)获取当前登录的userID,以便我可以更新一个使用此userID作为外键的表.问题是数据库中的userID与此不匹配:
Guid currentUser = (Guid)Membership.GetUser().ProviderUserKey; currentUser.toString();
结果在dffaca0c-ae0b-8549-8073-1639985740be中
而当我查看数据库时,它是0CCAFADF0BAE498580731639985740BE
为什么他们的价值不同? (我只有一个用户).我正在使用asp.net的oracle数据库和提供程序,但不应该有任何区别.
解决方法
我相信这些是相同的值,但显示顺序是不同的.看看2个值:
dffaca0c-ae0b-8549-8073-1639985740be 0CCAFADF-0BAE-4985-8073-1639985740BE
前3个段的字节顺序是不同的顺序:
0CCA FADF => FADF 0CCA => DFFA CA0C == dffaca0c 0BAE => AE 0B == ae0b 4985 => 85 49 == 8549
正如@ x0n评论,这看起来与Oracle的字节顺序不同.根据结构的this description,前8个字节的字节序是依赖于系统的,而最后8个字节的字节序特别是大字节序.