- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
据我所知,所有 Windows 版本和 .NET 都是小端。那么为什么要背离 Microsoft 的 SQL Server 规范呢?
我所说的“SQL Server is big endian”是这样的:
SELECT CONVERT(VARBINARY, 255);
0x000000FF
0xFF000000
BitConverter.GetBytes()
之类的方法。我猜 SQL Server 可能会在内部将数字存储为小端,然后
CONVERT
只是出于某种原因将其切换。但无论哪种方式,为什么呢?
DECLARE @q UNIQUEIDENTIFIER = '01234567-89ab-cdef-0123-456789abcdef';
SELECT @q;
SELECT CONVERT(VARBINARY, @q);
01234567-89AB-CDEF-0123-456789ABCDEF
0x67452301AB89EFCD0123456789ABCDEF
最佳答案
是的:Windows 和 .NET 是 Little Endian。
那么为什么 SQL Server 是 Big Endian?简单:这不是;-)。 Collation and Unicode Support 的 MSDN 页面(在 SQL Server 中)甚至指出:
Because the Intel platform is a little endian architecture, Unicode code characters are always stored byte-swapped.
DATETIME
到
INT
你会看到一个整数。但是,如果您将该 Integer 保存在 INT 字段中,它将以相反的顺序存储为 4 个字节,因为这是一个 Little Endian 系统。但这与您从系统请求返回该值并显示给您时所看到的内容无关。
INT
301
的值到
BINARY(2)
结果
0x012D
,因为 0x012D = 301,只是十六进制。所以转换
0x012D
返回
INT
返回
301
,正如预期的那样。如果原始的 Int 到 Binary 转换给你 0x2D01,那么,这并不等于 301。
SELECT CONVERT(BINARY(2), 301), CONVERT(INT, 0x012D)
-- 0x012D, 301
INT
的表列,并在该列中插入值“301”,然后使用
DBCC PAGE
要查看磁盘上存在的数据页,您将按所示顺序看到以下十六进制数字:
2D 01 00 00
BitConverter.ToString(BitConverter.GetBytes(255))
在 .NET 中将返回:
FF-00-00-00
GetBytes()
不是转换“值”,而是打算显示内部系统表示,这取决于系统是小端还是大端。如果您查看
BitConverter.GetBytes 的 MSDN 页面,它实际上在做什么可能会更清楚。
String.Format("{0:X8}", 255)
这将返回:
000000FF
SELECT CONVERT(BINARY(4), 255);
相同返回,因为它们都在转换值。此结果未显示为 Big Endian,而是显示为真实情况,恰好与 Big Endian 的字节顺序匹配。
100000000
的位序列开始时,可以用十进制形式表示为
256
,或十六进制形式(在 SQL Server 中称为
BINARY
/
VARBINARY
)如
0x0100
.字节顺序与此无关,因为它们只是表示相同潜在值的不同方式。
VARBINARY
之间转换时,可以看到 SQL Server 是 Little Endian 的进一步证据。和
NVARCHAR
.自
NVARCHAR
是 16 位(即 2 字节)编码,我们可以看到字节顺序,因为字符没有数字等价物(与 256 -> 0x0100 示例不同),因此实际上没有其他可显示的(显示代码点值是由于补充字符而不是一个选项)。
A
,其代码点为 U+0041(在数字上与 65 相同)转换为
VARBINARY
0x4100
的值,因为这是该字符的 UTF-16 Little Endian 编码值:
SELECT CONVERT(VARBINARY(10), N'A'), -- 0x4100
CONVERT(NVARCHAR(5), 0x4100), -- A
CONVERT(INT, 0x4100), -- 16640
UNICODE(N'A'), -- 65
CONVERT(VARBINARY(8), 65); -- 0x00000041
SELECT CONVERT(VARBINARY(10), N'ᄀ'), -- 0x0011
CONVERT(NVARCHAR(5), 0x0011), -- ᄀ
CONVERT(INT, 0x0011), -- 17
UNICODE(N'ᄀ'), -- 4352
CONVERT(VARBINARY(8), 4352); -- 0x00001100
NCHAR
函数允许)可以看到“
Pile of Poo”表情符号(代码点 U+01F4A9),或者您可以注入(inject) UTF-16 小端字节序列:
SELECT NCHAR(0xD83D) + NCHAR(0xDCA9) AS [SurrogatePair],
CONVERT(NVARCHAR(5), 0x3DD8A9DC) AS [UTF-16LE];
-- 💩 💩
UNIQUEIDENTIFIER
相似之处在于“它是什么”和“它是如何存储的”是两个不同的东西,它们不需要匹配。请记住,UUID/GUID 不是像
int
这样的基本数据类型。或
char
,但更像是一个具有定义格式的实体,就像 JPG 或 MP3 文件一样。更多关于
UNIQUEIDENTIFIER
的讨论s 在我对
related question 的回答中关于 DBA.StackExcange(包括为什么它由 Big Endian 和 Little Endian 的组合表示)。
关于sql-server - 为什么 SQL Server 是 Big Endian?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21793348/
这个问题已经有答案了: 已关闭10 年前。 Possible Duplicate: Big Theta Notation - what exactly does big Theta represent
我有一个作业要证明这些是对还是错: a) 150n^3 + 43n^2 + 50^n + 3 = Ω(n^5) b) n^10 + 30n^8 + 80n^6 = O(n^12) c) 55n + 3
我可以在 big.Int 上使用像 Text() 这样的方法,它工作正常,但是如果我返回一个 big.Int 然后使用“myfunc().Text()”会抛出一个错误,而如果我返回一个 * big.I
我正在用 PHP 开发一个网络应用程序,此时核心库的大小为 94kb。虽然我认为我现在是安全的,但多大才算太大?脚本的大小是否会成为一个问题,如果是这样,可以通过将脚本拆分为多个库来改善这一点吗? 我
我正在复习 Big-Oh 符号,但我在理解这个问题的解决方案时遇到了问题: Is 2n + 10 ≡ O(n)? Can we find c and n0? 2n + 10 = 10 n >= 10/
我最近陷入了争论/辩论中,我试图对正确的解决方案做出明确的判断。 众所周知, n! grows very quickly ,但究竟有多快,足以“隐藏”可能添加到其中的所有其他常量? 让我们假设我有这个
我很难找出这段代码的 Big-O 符号。 我需要找到两个 for 循环的符号。 public static int fragment(int n) { int sum = 0; for (in
给定两个函数: f(n)=O(log2n) 和 g(n)=O(log10n) 其中一个是否支配另一个? 最佳答案 请记住,任何碱基的对数都可以转换为仅以常数变化的公共(public)碱基。 因此它们都
经过修改,我们得出结论,时间复杂度实际上是O(2^n) 问题是时间复杂度是多少?是 O(2^n) 还是? 我相信这是因为 for 循环被认为运行了 n 次。然后嵌套的 while 循环运行 2^n 次
以下嵌套循环的 Big-O 时间复杂度是多少: for (int i = 0; i < N; i++) { for (int j = i + 1; j < N; j++) {
我很想知道经验丰富的 C 程序员认为可以按值传递的参数大小的上限是什么。 上下文:我有机会使用 2×2 矩阵,它位于一个结构体中: typedef struct { double a, b, c,
我很想知道经验丰富的 C 程序员认为可以按值传递的参数大小的上限是什么。 上下文:我有机会使用 2×2 矩阵,它位于一个结构体中: typedef struct { double a, b, c,
假设我们有一个问题,我们使用 X 算法实现了 O(n) 或 O(log n) 或 etc...。 n 的值何时大到我们必须考虑替代实现?让我们看看我是否可以更好地解释自己。 For n=10,000
这属于哪种 Big-O 表示法?我知道 setSearch() 和 removeAt() 是 O(n) 的顺序(假设它们是任意一种)。我知道如果没有 for 循环它肯定是 O(n),但是我很困惑如何计
这是我的问题,我已经设法为 a 部分提出了一个答案,但对于 b 部分,我对 b 部分的答案并不是很自信。 在最近的一起法庭案件中,一名法官以蔑视城市为由,下令第一天罚款 2 美元。 之后的每一天,直到
我正在尝试计算以下算法的大 O,但我很困惑,需要一些帮助: Algorithm 1. DFS(G,n) Input: G- the graph n- the current node 1
我们有一个使用 F5 BIG-IP 服务器进行负载平衡的潜在客户端。在确定我们是否可以将我们的产品与他们的负载均衡器干净地集成时,我开始查看 F5 提供的 API。问题是,如果没有 F5 服务器,我无
我正在尝试使用 react-big-calendar 包。 http://intljusticemission.github.io/react-big-calendar/examples/index.
我的任务是尝试找到给定 Java 方法的 big-O 和 big-Omega,但不知道如何找到。我知道 big-O 给出了上限,big-Omega 给出了下限,但是在查看程序(更不用说递归程序)时,我
我正在尝试确定以下陈述是对还是错。 如果 f(n) ∈ O(n) 且 g(n) ∈ Ω(n),则 f(n) + g(n) ∈ Θ(n)。 我想我理解添加相同的渐近 big-O。 O(n) + O(n)
我是一名优秀的程序员,十分优秀!