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 @ 2023-06-30 17:30  苹果芒  阅读(146)  评论(0编辑  收藏  举报