Skip to content

Commit

Permalink
Merge pull request #44 from vnobo/dev
Browse files Browse the repository at this point in the history
Dev
  • Loading branch information
vnobo authored Dec 23, 2024
2 parents cbe0720 + f939263 commit 1739b01
Show file tree
Hide file tree
Showing 18 changed files with 99 additions and 128 deletions.
2 changes: 1 addition & 1 deletion boot/platform/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ dependencies {
implementation("org.springframework.boot:spring-boot-starter-data-redis-reactive")

//implementation("org.springframework.boot:spring-boot-starter-jooq")
implementation("org.jooq:jooq")
//implementation("org.jooq:jooq")
implementation("org.springframework.boot:spring-boot-starter-data-r2dbc")
implementation("org.postgresql:r2dbc-postgresql")

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@
import com.plate.boot.security.SecurityDetails;
import com.plate.boot.security.core.user.UsersService;
import lombok.extern.log4j.Log4j2;
import org.jooq.DSLContext;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.http.HttpHeaders;
import org.springframework.http.server.reactive.ServerHttpRequest;
Expand Down Expand Up @@ -107,18 +106,15 @@ public final class ContextUtils implements InitializingBean {
*/
public static UsersService USERS_SERVICE;

public static DSLContext JOOQDSL;

/**
* Initializes the ContextUtils class with necessary dependencies.
*
* @param objectMapper The ObjectMapper instance used for JSON serialization and deserialization.
* @param usersService The UsersService instance to provide access to user-related operations.
*/
ContextUtils(ObjectMapper objectMapper, UsersService usersService, DSLContext create) {
ContextUtils(ObjectMapper objectMapper, UsersService usersService) {
ContextUtils.OBJECT_MAPPER = objectMapper;
ContextUtils.USERS_SERVICE = usersService;
ContextUtils.JOOQDSL = create;
}

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,11 +20,11 @@
* <pre>
* {@code
* QueryFragment queryFragment = QueryFragment.withNew()
* .addColumn("id", "name", "email")
* .addQuery("users")
* .addWhere("age > :age", 18)
* .addOrder("name ASC")
* .addOrder("email DESC");
* .columns("id", "name", "email")
* .query("users")
* .where("age > :age", 18)
* .orderBy("name ASC")
* .orderBy("email DESC");
*
* // Bind parameters
* queryFragment.put("age", 18);
Expand All @@ -48,7 +48,7 @@ public class QueryFragment extends HashMap<String, Object> {
* Example usage:
* <pre>
* {@code
* queryFragment.addColumn("id", "name", "email");
* queryFragment.columns("id", "name", "email");
* }
* </pre>
*/
Expand All @@ -59,18 +59,18 @@ public class QueryFragment extends HashMap<String, Object> {
* Example usage:
* <pre>
* {@code
* queryFragment.addQuery("users");
* queryFragment.query("users");
* }
* </pre>
*/
private final StringJoiner select = new StringJoiner(" ");
private final StringJoiner from = new StringJoiner(" ");

/**
* A StringJoiner to accumulate WHERE conditions.
* Example usage:
* <pre>
* {@code
* queryFragment.addWhere("age > :age");
* queryFragment.where("age > :age");
* }
* </pre>
*/
Expand All @@ -81,7 +81,7 @@ public class QueryFragment extends HashMap<String, Object> {
* Example usage:
* <pre>
* {@code
* queryFragment.addOrder("name ASC");
* queryFragment.orderBy("name ASC");
* }
* </pre>
*/
Expand All @@ -92,108 +92,96 @@ public class QueryFragment extends HashMap<String, Object> {
/**
* The maximum number of rows to return (LIMIT clause).
*/
private final int size;
private int size = 25;

/**
* The number of rows to skip before starting to return rows (OFFSET clause).
*/
private final long offset;
private long offset = 0;

public QueryFragment(int size, long offset, QueryFragment params) {
super(16);
this.size = size;
this.offset = offset;
this.mergeWhere(params.getWhere());
this.putAll(params);
public QueryFragment(QueryFragment fragment) {
super(fragment);
this.size = fragment.size;
this.offset = fragment.offset;
this.columns.merge(fragment.getColumns());
this.from.merge(fragment.getFrom());
this.orderBy.merge(fragment.getOrderBy());
this.where.merge(fragment.getWhere());
}

public QueryFragment(int size, long offset, Map<String, Object> params) {
super(16);
this.size = size;
this.offset = offset;
this.putAll(params);
/**
* Creates a new QueryFragment instance with the specified parameters.
*
* @param params the parameters to initialize the QueryFragment with
*/
public QueryFragment(Map<String, Object> params) {
super(params);
}

public static QueryFragment withNew() {
return withMap(Map.of());
}

public static QueryFragment withMap(Map<String, Object> params) {
return new QueryFragment(Integer.MAX_VALUE, 0, params);
return new QueryFragment(params);
}

public static QueryFragment withMap(int size, long offset, Map<String, Object> params) {
return new QueryFragment(size, offset, params);
return withMap(params).limit(size, offset);
}

public static QueryFragment of(QueryFragment params) {
return of(Integer.MAX_VALUE, 0, params);
}

public static QueryFragment of(int size, long offset, QueryFragment params) {
return new QueryFragment(size, offset, params);
return of(params).limit(size, offset);
}

public QueryFragment addColumn(CharSequence... columns) {
public QueryFragment columns(CharSequence... columns) {
for (CharSequence column : columns) {
this.columns.add(column);
}
return this;
}

public QueryFragment addQuery(CharSequence... queries) {
this.select.setEmptyValue("");
public QueryFragment query(CharSequence... queries) {
this.from.setEmptyValue("");
for (CharSequence query : queries) {
this.select.add(query);
this.from.add(query);
}
return this;
}

public QueryFragment addWhere(CharSequence where) {
public QueryFragment where(CharSequence where) {
this.where.add(where);
return this;
}

/**
* Adds an ORDER BY clause to the query.
*
* @param order the order
* @return this
* @param order the order to add
* @return the QueryFragment instance
*/
public QueryFragment addOrder(CharSequence order) {
public QueryFragment orderBy(CharSequence order) {
this.orderBy.add(order);
return this;
}

/**
* Merges the given where clause with the existing one.
*
* @param where the where
* @return this
*/
public QueryFragment mergeWhere(StringJoiner where) {
this.where.merge(where);
return this;
}

/**
* Merges the given order clause with the existing one.
* Adds a GROUP BY clause to the query.
*
* @param order the order
* @return this
* @param size page size
* @param offset page offset
* @return the QueryFragment instance
*/
public QueryFragment mergeOrder(StringJoiner order) {
this.orderBy.merge(order);
public QueryFragment limit(int size, long offset) {
this.size = size;
this.offset = offset;
return this;
}

/**
* Generates the WHERE clause part of a SQL query based on the stored conditions.
* If conditions have been accumulated, it prefixes the conditions with the 'WHERE' keyword;
* otherwise, it returns an empty string to indicate no conditions.
*
* @return A String forming the WHERE clause of the SQL query, or an empty string if no conditions are present.
*/
public String whereSql() {
if (this.where.length() > 0) {
return " WHERE " + this.where;
Expand All @@ -220,9 +208,9 @@ public String orderSql() {
* @throws QueryException if the querySql is null, indicating that the query structure is incomplete.
*/
public String querySql() {
if (this.select.length() > 0) {
if (this.from.length() > 0) {
return String.format("SELECT %s FROM %s %s %s LIMIT %d OFFSET %d",
this.columns, this.select, whereSql(), orderSql(), this.size, this.offset);
this.columns, this.from, whereSql(), orderSql(), this.size, this.offset);
}
throw QueryException.withError("This querySql is null, please use whereSql() method!",
new IllegalArgumentException("This querySql is null, please use whereSql() method"));
Expand All @@ -240,8 +228,8 @@ public String querySql() {
* @throws QueryException if the countSql is null, indicating that the query structure is incomplete.
*/
public String countSql() {
if (this.select.length() > 0) {
return "SELECT COUNT(*) FROM (" + String.format("SELECT %s FROM %s", this.columns, this.select)
if (this.from.length() > 0) {
return "SELECT COUNT(*) FROM (" + String.format("SELECT %s FROM %s", this.columns, this.from)
+ whereSql() + ") t";
}
throw QueryException.withError("This countSql is null, please use whereSql() method!",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -241,7 +241,7 @@ private static void processQueryKey(QueryFragment queryFragment, Map<String, Obj
if (objectMap.containsKey("query")) {
var jsonMap = (Map<String, Object>) objectMap.get("query");
var jsonQueryFragment = QueryJsonHelper.queryJson(jsonMap, prefix);
queryFragment.mergeWhere(jsonQueryFragment.getWhere());
queryFragment.getWhere().merge(jsonQueryFragment.getWhere());
queryFragment.putAll(jsonQueryFragment);
}
}
Expand All @@ -257,7 +257,7 @@ private static void processQueryKey(QueryFragment queryFragment, Map<String, Obj
private static void processSecurityCodeKey(QueryFragment queryFragment, Map<String, Object> objectMap, Collection<String> skipKeys, String prefix) {
if (!skipKeys.contains("securityCode") && objectMap.containsKey("securityCode")) {
var column = StringUtils.hasLength(prefix) ? prefix + ".tenant_code" : "tenant_code";
queryFragment.addWhere(column + " LIKE :securityCode");
queryFragment.where(column + " LIKE :securityCode");
queryFragment.put("securityCode", objectMap.get("securityCode"));
}
}
Expand All @@ -273,9 +273,9 @@ private static void processSearchKey(QueryFragment queryFragment, Map<String, Ob
if (objectMap.containsKey("search") && !ObjectUtils.isEmpty(objectMap.get("search"))) {
var textSearch = (String) objectMap.get("search");
var column = StringUtils.hasLength(prefix) ? prefix + ".text_search" : "text_search";
queryFragment.addColumn("TS_RANK_CD(" + column + ", queryTextSearch) AS rank");
queryFragment.addQuery(",TO_TSQUERY('chinese',:textSearch) queryTextSearch");
queryFragment.addWhere(column + "@@TO_TSQUERY('chinese',:textSearch)");
queryFragment.columns("TS_RANK_CD(" + column + ", queryTextSearch) AS rank");
queryFragment.query(",TO_TSQUERY('chinese',:textSearch) queryTextSearch");
queryFragment.where(column + "@@TO_TSQUERY('chinese',:textSearch)");
queryFragment.put("textSearch", textSearch);
}
}
Expand Down Expand Up @@ -317,7 +317,7 @@ public static void applySort(QueryFragment queryFragment, Sort sort, String pref
if (StringUtils.hasLength(prefix)) {
sortedProperty = prefix + "." + sortedProperty;
}
queryFragment.addOrder(sortedProperty + (order.isAscending() ? " ASC" : " DESC"));
queryFragment.orderBy(sortedProperty + (order.isAscending() ? " ASC" : " DESC"));
}
}

Expand All @@ -330,7 +330,7 @@ public static void applySort(QueryFragment queryFragment, Sort sort, String pref
public static void applyWhere(QueryFragment queryFragment, String prefix) {
for (Map.Entry<String, Object> entry : queryFragment.entrySet()) {
String conditionSql = buildConditionSql(entry, prefix);
queryFragment.addWhere(conditionSql);
queryFragment.where(conditionSql);
}
}

Expand All @@ -352,8 +352,8 @@ public static void applyQuerySql(QueryFragment queryFragment, Object object) {
}

String tableName = StringUtils.hasLength(table.value()) ? table.value() : objectClass.getName();
queryFragment.addColumn("*");
queryFragment.addQuery(tableName);
queryFragment.columns("*");
queryFragment.query(tableName);
}

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -165,7 +165,7 @@ public static QueryFragment queryJson(Map<String, Object> params, String prefix)
QueryFragment queryFragment = QueryFragment.withNew();
for (Map.Entry<String, Object> entry : params.entrySet()) {
var condition = buildJsonCondition(entry, prefix);
queryFragment.mergeWhere(condition.getWhere());
queryFragment.getWhere().merge(condition.getWhere());
queryFragment.putAll(condition);
}
return queryFragment;
Expand Down Expand Up @@ -232,7 +232,7 @@ private static QueryFragment buildJsonCondition(Map.Entry<String, Object> entry,
//处理最后键
QueryFragment lastCondition = buildLastCondition(keys, entry.getValue());
conditionBuilder.append(lastCondition.getWhere());
return QueryFragment.withMap(lastCondition).addWhere(conditionBuilder.toString());
return QueryFragment.withMap(lastCondition).where(conditionBuilder.toString());
}

/**
Expand Down Expand Up @@ -260,7 +260,7 @@ private static QueryFragment buildLastCondition(String[] keys, Object value) {
Map.Entry<String, String> exps = queryKeywordMapper(lastKey);
if (exps == null) {
conditionSql.append(lastKey).append("' = :").append(paramName);
return QueryFragment.withMap(Map.of(paramName, value)).addWhere(conditionSql.toString());
return QueryFragment.withMap(Map.of(paramName, value)).where(conditionSql.toString());
}

String key = lastKey.substring(0, lastKey.length() - exps.getKey().length());
Expand All @@ -280,7 +280,7 @@ private static QueryFragment buildLastCondition(String[] keys, Object value) {
conditionSql.append(exps.getValue()).append(" :").append(paramName);
params = Map.of(paramName, value);
}
return QueryFragment.withMap(params).addWhere(conditionSql.toString());
return QueryFragment.withMap(params).where(conditionSql.toString());
}

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,17 +6,13 @@
import io.r2dbc.spi.ConnectionFactories;
import io.r2dbc.spi.ConnectionFactory;
import lombok.RequiredArgsConstructor;
import org.jooq.DSLContext;
import org.jooq.SQLDialect;
import org.jooq.impl.DSL;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.convert.converter.Converter;
import org.springframework.data.domain.ReactiveAuditorAware;
import org.springframework.data.r2dbc.config.AbstractR2dbcConfiguration;
import org.springframework.data.r2dbc.config.EnableR2dbcAuditing;
import org.springframework.lang.NonNull;
import org.springframework.r2dbc.connection.TransactionAwareConnectionFactoryProxy;
import org.springframework.transaction.annotation.EnableTransactionManagement;

import java.util.List;
Expand Down Expand Up @@ -75,11 +71,4 @@ public ReactiveAuditorAware<UserAuditor> userAuditorProvider() {
return new UserAuditorAware();
}

@Bean
public DSLContext dslContext(ConnectionFactory connectionFactory) {
return DSL.using(
new TransactionAwareConnectionFactoryProxy(connectionFactory),
SQLDialect.POSTGRES
);
}
}
Loading

0 comments on commit 1739b01

Please sign in to comment.