package com.jsh.erp.utils;
|
|
/**
|
* @author jishenghua qq752718920 2018-10-7 15:26:27
|
*/
|
public class OrderUtils {
|
|
/**
|
* 将指定字段排序
|
*
|
* @param orders 格式 属性名,排序方式 例如( name,asc或ip,desc)
|
* @return 排序字符串 例如:(name asc 或 ip desc)
|
*/
|
public static String getOrderString(String orders) {
|
if (StringUtil.isNotEmpty(orders)) {
|
String[] splits = orders.split(Constants.SPLIT);
|
if (splits.length == 2) {
|
String column = ColumnPropertyUtil.propertyToColumn(splits[0]);
|
if (column.equals("audit_status")) {
|
// TODO: 2015/12/24 这么处理不好,得相伴办法调整
|
return "IF(`audit_status`=3,-1,`audit_status`) " + splits[1];
|
} else if (column.equals("create_time") || column.equals("modify_time")) {
|
// TODO: 2015/12/24 这么处理不好,得相伴办法调整
|
return column + " " + splits[1];
|
} else {
|
return "convert(" + column + " using gbk) " + splits[1];
|
}
|
}
|
}
|
return "";
|
}
|
|
public static String getJoinTablesOrderString(String orders, String tableName) {
|
if (StringUtil.isNotEmpty(orders)) {
|
String[] splits = orders.split(Constants.SPLIT);
|
if (splits.length == 2) {
|
return "convert(" + tableName + "." + ColumnPropertyUtil.propertyToColumn(splits[0]) + " using gbk) " + splits[1];
|
}
|
}
|
return "";
|
}
|
|
|
/**
|
* 将指定字段排序
|
* inet_aton:mysql将IP 转成 long类别函数
|
*
|
* @param orders 格式 属性名,排序方式 例如( name,asc或ip,desc)
|
* @param ipPropertyName 如果需要按IP属性排序,需要将属性名传入(可不传)
|
* @return 排序字符串 例如:(name asc 或 ip desc)
|
*/
|
public static String getOrderString(String orders, String... ipPropertyName) {
|
if (StringUtil.isNotEmpty(orders)) {
|
String[] splits = orders.split(Constants.SPLIT);
|
if (splits.length == 2) {
|
String column = ColumnPropertyUtil.propertyToColumn(splits[0]);
|
if (ipPropertyName != null && ipPropertyName.length > 0) {
|
for (String ip : ipPropertyName) {
|
if (ip.equals(column)) {
|
return "inet_aton(" + column + ") " + splits[1];
|
}
|
}
|
}
|
return column + " " + splits[1];
|
}
|
}
|
return "";
|
}
|
}
|