如果你的强制转换不起作用,那么你可以使用 yourColumnName*1 与 ORDER BY 子句。使用 yourColumnName*1。语法如下:SELECT yourColumnName1, yourColumnName2, ...N FROM yourTableName ORDER BY yourColumnName*1 DESC;你也可以使用 CAST() 运算符。语法如下:SELECT yourColumnName1, yourColumnName2, ...N FROM yourTableName ORDER BY CAST(yourColumnName as DECIMAL(8, 2)) DESC;为了理解上述语法,让我们创建一个表。创建表的查询如下:mysql> create table VarcharColumnAsFloatDemo -> ( -> Id int NOT NULL AUTO_INCREMENT, -> Amount varchar(20), -> PRIMARY KEY(Id) ... 阅读更多
使用 ORDER BY 子句和 IS NULL 属性按日期排序并将空日期设置在最后。语法如下:SELECT *FROM yourTableName ORDER BY (yourDateColumnName IS NULL), yourDateColumnName DESC;在上述语法中,我们将首先对 NULL 进行排序,然后对日期进行排序。为了理解上述语法,让我们创建一个表。创建表的查询如下:mysql> create table DateColumnWithNullDemo -> ( -> Id int NOT NULL AUTO_INCREMENT, -> LoginDateTime datetime, -> PRIMARY KEY(Id) -> ... 阅读更多
要查找列的第 n 大值,你需要使用带有 LIMIT 子句的 ORDER BY DESC。如果你想要列的第二大值,请使用以下语法:SELECT *FROM yourTableName ORDER BY DESC yourColumnName LIMIT 1, 1;如果你想要列的第四大值,请使用以下语法:SELECT *FROM yourTableName ORDER BY DESC yourColumnName LIMIT 3, 1;如果你想要列的第一大值,请使用以下语法:SELECT *FROM yourTableName ORDER BY DESC yourColumnName LIMIT 1;如上述语法中所述,你只需要更改 LIMIT 子句。为了理解 ... 阅读更多
如果尝试设置高于允许限制的数据,则可能会发生此错误。例如,你不能在 bit 类型的列中存储字符串,因为 varchar 或字符串占用的空间大于 bit 数据类型。你需要对 bit 类型列使用以下语法:anyBitColumnName= b ‘1’ OR anyBitColumnName= b ‘0’为了理解上述语法,让我们创建一个表。创建表的查询如下:mysql> create table IncasesensitiveDemo -> ( -> Id int NOT NULL AUTO_INCREMENT, -> Name varchar(10), -> PRIMARY KEY(Id) -> ); Query OK, ... 阅读更多