mysql 如何 使用一个字符串来进行排序

如果想进行对一个字段进行排序,但是这个字段却不是int类型,适应varchar类型怎么办呢?

常用的方式:

给字符字段加上0,举例:

1:假设scoreRate是一个varchar类型,并且值是一个百分(90%)的数据格式.

要求:请获取scoreRate值最高的一条数据:

sql:

select * from resultTable order by replace(scoreRate,"%","")+0 desc limit 1

 

2.如果createTime字段是一个varchar类型,并且是一个日期时间:2013-08-11 13:30:33这样格式的数据

要求:获取某个年份和月份 时间区间的数据

SELECT * FROM student where className="classOne" AND createTime between '2023-02' and '2023-07'  order id desc;
 

要求:获取某个具体年份和月份,日期 时间区间的数据

SELECT * FROM student where className="classOne" AND createTime between '2023-02-01' and '2023-07-31'  order id desc;

 

3. 如果createTime字段是一个varchar类型,并且是一个日期时间:2013-08-11 13:30:33这样格式的数据

要求:按年份,月份来进行聚合 求和

复制代码
SELECT 
sum(score)as totalScores,
year(createTime) as year,
month(createTime) as month
FROM student 
where className="classOne" group by year(createTime),month(createTime);
复制代码

 

posted @   苹果芒  阅读(176)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
点击右上角即可分享
微信分享提示