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);