Skip to content

Commit

Permalink
https://github.com/danieleteti/delphimvcframework/issues/565
Browse files Browse the repository at this point in the history
  • Loading branch information
danieleteti committed Aug 9, 2022
1 parent 2e91fb6 commit 31dee93
Show file tree
Hide file tree
Showing 7 changed files with 89 additions and 62 deletions.
4 changes: 4 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -528,6 +528,8 @@ The current beta release is named 3.2.2-nitrogen. If you want to stay on the-edg
- ✅ Improved! Now `TMVCStaticFileMiddleware` is able to manage high-level criteria to show/hide/mask specific files in the documetn web root. Check [Issue 548](https://github.com/danieleteti/delphimvcframework/issues/548) and the updated sample `samples\middleware_staticfiles\` for more info.
- ✅ Improved! In case of multiple MVCPath, Swagger consider only the first one (Thanks to V. Ferri and our sponsors)
- ⚡New! Mechanism to customize the JWT claims setup using the client request as suggested in [issue495](https://github.com/danieleteti/delphimvcframework/issues/495)
- ⚡New! Added `TMVCActiveRecord.Merge<T>(CurrentListOfT, ChangesOfT)` to allow merge between two lists of `TMVCActiveRecord` descendants using `UnitOfWork` design pattern. Check the button "Merge" in demo "activerecord_showcase".
Expand Down Expand Up @@ -707,6 +709,8 @@ The current beta release is named 3.2.2-nitrogen. If you want to stay on the-edg
- Fix https://github.com/danieleteti/delphimvcframework/issues/570 (Thanks [Marcos Nielsen](https://github.com/marcosnielsen))
- Fix https://github.com/danieleteti/delphimvcframework/issues/565
- Merged [PR#543](https://github.com/danieleteti/delphimvcframework/pull/543) (Now the `PathInfo` is trimmed so the router convert this "http://myserver.com/one " to this "http://myserver.com/one")
- Fix for nil objects in lists during serialization
Expand Down
31 changes: 17 additions & 14 deletions samples/activerecord_showcase/FDConnectionConfigU.pas
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,9 @@ procedure CreateMySQLPrivateConnDef(AIsPooled: boolean);
var
LParams: TStringList;
begin
{
docker run --detach --env MARIADB_USER=example-user --env MARIADB_PASSWORD=my_cool_secret --env MARIADB_ROOT_PASSWORD=root -p 3306:3306 mariadb:latest
}
{
docker run --detach --env MARIADB_USER=example-user --env MARIADB_PASSWORD=my_cool_secret --env MARIADB_ROOT_PASSWORD=root -p 3306:3306 mariadb:latest
}

LParams := TStringList.Create;
try
Expand All @@ -35,7 +35,7 @@ procedure CreateMySQLPrivateConnDef(AIsPooled: boolean);
LParams.Add('User_Name=root');
LParams.Add('Password=root');
LParams.Add('TinyIntFormat=Boolean'); { it's the default }
LParams.Add('CharacterSet=utf8mb4'); //not utf8!!
LParams.Add('CharacterSet=utf8mb4'); // not utf8!!
if AIsPooled then
begin
LParams.Add('Pooled=True');
Expand All @@ -55,9 +55,9 @@ procedure CreateMSSQLServerPrivateConnDef(AIsPooled: boolean);
var
LParams: TStringList;
begin
{
docker run -e "ACCEPT_EULA=Y" -e "SA_PASSWORD=!SA_password!" -p 1433:1433 -d mcr.microsoft.com/mssql/server:2019-latest
}
{
docker run -e "ACCEPT_EULA=Y" -e "SA_PASSWORD=!SA_password!" -p 1433:1433 -d mcr.microsoft.com/mssql/server:2019-latest
}

// [ACTIVERECORDB_SQLSERVER]
// Database=activerecorddb
Expand All @@ -69,10 +69,10 @@ procedure CreateMSSQLServerPrivateConnDef(AIsPooled: boolean);
LParams := TStringList.Create;
try
LParams.Add('Database=activerecorddb');
// LParams.Add('OSAuthent=Yes');
LParams.Add('User_Name=sa');
LParams.Add('Password=!SA_password!');
LParams.Add('Server=DANIELETETI');
LParams.Add('OSAuthent=Yes');
// LParams.Add('User_Name=sa');
// LParams.Add('Password=sa');
LParams.Add('Server=DANIELETETI\SQLEXPRESS');
// LParams.Add('TinyIntFormat=Boolean'); { it's the default }
if AIsPooled then
begin
Expand All @@ -95,7 +95,8 @@ procedure CreateFirebirdPrivateConnDef(AIsPooled: boolean);
begin
LParams := TStringList.Create;
try
LParams.Add('Database=' + TPath.GetFullPath(TPath.Combine('..', 'data\ACTIVERECORDDB.FDB')));
LParams.Add('Database=' + TPath.GetFullPath(TPath.Combine('..',
'data\ACTIVERECORDDB.FDB')));
LParams.Add('Protocol=TCPIP');
LParams.Add('Server=localhost');
LParams.Add('User_Name=sysdba');
Expand All @@ -122,7 +123,8 @@ procedure CreateInterbasePrivateConnDef(AIsPooled: boolean);
begin
LParams := TStringList.Create;
try
LParams.Add('Database=' + TPath.GetFullPath(TPath.Combine('..\..', 'data\ACTIVERECORDDB.IB')));
LParams.Add('Database=' + TPath.GetFullPath(TPath.Combine('..\..',
'data\ACTIVERECORDDB.IB')));
LParams.Add('Protocol=TCPIP');
LParams.Add('Server=localhost');
LParams.Add('User_Name=sysdba');
Expand Down Expand Up @@ -179,7 +181,8 @@ procedure CreateSqlitePrivateConnDef(AIsPooled: boolean);
begin
LParams := TStringList.Create;
try
lFName := TPath.Combine(TPath.GetDirectoryName(ParamStr(0)), '..\..\data\activerecorddb.db');
lFName := TPath.Combine(TPath.GetDirectoryName(ParamStr(0)),
'..\..\data\activerecorddb.db');
LParams.Add('Database=' + lFName);
LParams.Add('StringFormat=Unicode');
if AIsPooled then
Expand Down
1 change: 1 addition & 0 deletions samples/activerecord_showcase/MainFormU.pas
Original file line number Diff line number Diff line change
Expand Up @@ -1008,6 +1008,7 @@ procedure TMainForm.btnRQLClick(Sender: TObject);
cRQL2 = 'and(eq(City,"Rome"),or(contains(CompanyName,"GAS"),contains(CompanyName,"Motors")))';
begin
LoadCustomers;

Log('** RQL Queries Test');
Log('>> RQL Query (1) - ' + cRQL1);
lList := TMVCActiveRecord.SelectRQL(TCustomer, cRQL1, 20);
Expand Down
1 change: 1 addition & 0 deletions samples/rql2sql/bin/rqlhistory.txt
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
and(eq(City,"Rome"),or(contains(CompanyName,"GAS"),contains(CompanyName,"Motors")))
starts(nome,"J")
out(name,["daniele","scott"])
out ( value , [ 1 , 2 , 3 ] )
Expand Down
50 changes: 2 additions & 48 deletions sources/MVCFramework.ActiveRecord.pas
Original file line number Diff line number Diff line change
Expand Up @@ -3280,53 +3280,6 @@ function TMVCSQLGenerator.MergeDefaultRQLFilter(const RQL: String): String;
begin
Result := Result + ';' + lRQLSortingAndLimitPart;
end;

//
// var Pieces := RQL.Split([';']);
// if Pieces[0].Trim.Length > 0 then
// begin
// Result := 'and('+fDefaultRQLFilter + ',' + Pieces[0] + ');' + string.Join(';', Pieces, 1, Length(Pieces)-1);
// end
// else
// begin
// Result := fDefaultRQLFilter + ';' + string.Join(';', Pieces, 1, Length(Pieces)-1);
// end;
// end
//
//
//
// if not fDefaultRQLFilter.IsEmpty then
// begin
// if RQL.Contains(';') then
// begin
// var Pieces := RQL.Split([';']);
// if Pieces[0].Trim.Length > 0 then
// begin
// Result := 'and('+fDefaultRQLFilter + ',' + Pieces[0] + ');' + string.Join(';', Pieces, 1, Length(Pieces)-1);
// end
// else
// begin
// Result := fDefaultRQLFilter + ';' + string.Join(';', Pieces, 1, Length(Pieces)-1);
// end;
// end
// else
// begin
// if RQL.IsEmpty then
// begin
// Result := fDefaultRQLFilter
// end
// else
// begin
// Result := MergeRQL(Result, fPartitionInfo.RQLFilter);
// end;
// //Result := 'and('+fDefaultRQLFilter + ',' + RQL + ')';
// end;
// end
// else
// begin
// Result := RQL;
// end;
// Result := MergeRQL(Result, fPartitionInfo.RQLFilter);
end;

function TMVCSQLGenerator.MergeSQLFilter(const SQL1, SQL2: String): String;
Expand Down Expand Up @@ -3430,7 +3383,8 @@ class function TMVCActiveRecord.ExecQuery(const SQL: string; const Values: array
begin
lQry.Connection := Connection;
end;
lQry.SQL.Text := SQL;
// lQry.SQL.Clear;
// lQry.SQL.Add(SQL);
// lQry.Prepare;
if Length(ValueTypes) = 0 then
begin
Expand Down
29 changes: 29 additions & 0 deletions sources/MVCFramework.RQL.AST2MSSQL.pas
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,7 @@ TRQLMSSQLCompiler = class(TRQLCompiler)
function RQLWhereToSQL(const aRQLWhere: TRQLWhere): string;
function RQLLogicOperatorToSQL(const aRQLFIlter: TRQLLogicOperator): string;
protected
procedure AdjustAST(const aRQLAST: TRQLAbstractSyntaxTree); override;
function RQLCustom2SQL(const aRQLCustom: TRQLCustom): string; override;
end;

Expand All @@ -49,6 +50,34 @@ implementation

{ TRQLMSSQLCompiler }

procedure TRQLMSSQLCompiler.AdjustAST(const aRQLAST: TRQLAbstractSyntaxTree);
var
lLimit, lTmp: TRQLCustom;
lSort: TRQLSort;
begin
inherited;
if aRQLAST.TreeContainsToken(tkLimit, lLimit) then
begin
if TRQLLimit(lLimit).Count = 0 then
begin
raise ERQLException.Create('MSSQL Server do not support "FETCH NEXT 0"');
end;
if not aRQLAST.TreeContainsToken(tkSort, lTmp) then
begin
if aRQLAST.Last is TRQLLimit then
begin
lSort := TRQLSort.Create;
aRQLAST.Insert(aRQLAST.Count-1, lSort);
lSort.Add('+', GetPKFieldName);
end
else
begin
raise ERQLException.Create('Invalid position for RQLLimit');
end;
end;
end;
end;

function TRQLMSSQLCompiler.RQLCustom2SQL(
const aRQLCustom: TRQLCustom): string;
begin
Expand Down
35 changes: 35 additions & 0 deletions sources/MVCFramework.RQL.Parser.pas
Original file line number Diff line number Diff line change
Expand Up @@ -94,6 +94,7 @@ TRQLCompiler = class abstract
function GetDatabaseFieldName(const RQLPropertyName: string; const UsePropertyNameIfAttributeDoesntExists: Boolean = False): string;
function QuoteStringArray(const aStringArray: TArray<string>): TArray<string>;
function RQLCustom2SQL(const aRQLCustom: TRQLCustom): string; virtual; abstract;
procedure AdjustAST(const aRQLAST: TRQLAbstractSyntaxTree); virtual;
public
constructor Create(const Mapping: TMVCFieldsMapping); virtual;
procedure AST2SQL(const aRQLAST: TRQLAbstractSyntaxTree; out aSQL: string); virtual;
Expand All @@ -104,6 +105,7 @@ TRQLCompiler = class abstract
// or if the field name contains spaces.
function GetFieldNameForSQL(const FieldName: string): string; virtual;
function GetParamNameForSQL(const FieldName: string): string; virtual;
function GetPKFieldName: String;
end;

TRQLCompilerClass = class of TRQLCompiler;
Expand Down Expand Up @@ -368,6 +370,28 @@ procedure TRQL2SQL.Execute(
end;


// if fAST.TreeContainsToken(tkLimit, lRQLItem) then
// begin
// if (TRQLLimit(lRQLItem).Count > 0) and (not fAST.TreeContainsToken(tkSort, lRQLItem)) then
// begin
// lSort := TRQLSort.Create;
// lSort.Add('+', '1');
// fAST.Insert(fAST.Count-1, lSort);
// end
// else
// begin
// fAST.Remove(lRQLItem);
// fAST.TreeContainsToken(tk)
// fAST.Add(lAlwaysFalse);
// lAlwaysFalse.OpLeft := '1';
// lAlwaysFalse.OpRight := '2';
// lAlwaysFalse.RightValueType := vtInteger;
// lAlwaysFalse.Token := tkEq;
// end;
// end;



if UseFilterOnly then
{If we need only the filter part, remove sort and limit tokens}
begin
Expand Down Expand Up @@ -1151,6 +1175,11 @@ procedure TRQLCompilerRegistry.UnRegisterCompiler(const aBackend: string);

{ TRQLCompiler }

procedure TRQLCompiler.AdjustAST(const aRQLAST: TRQLAbstractSyntaxTree);
begin
//do nothing
end;

procedure TRQLCompiler.AST2SQL(const aRQLAST: TRQLAbstractSyntaxTree;
out aSQL: string);
var
Expand All @@ -1165,6 +1194,7 @@ procedure TRQLCompiler.AST2SQL(const aRQLAST: TRQLAbstractSyntaxTree;
For MSSQL syntax you need to rearrange in: limit, filters, sort
}

AdjustAST(aRQLAST);
lBuff := TStringBuilder.Create;
try
for lItem in aRQLAST do
Expand Down Expand Up @@ -1237,6 +1267,11 @@ function TRQLCompiler.GetParamNameForSQL(const FieldName: string): string;
Result := FieldName.Replace(' ', '_', [rfReplaceAll]);
end;

function TRQLCompiler.GetPKFieldName: String;
begin
Result := fMapping[0].InstanceFieldName;
end;

function TRQLCompiler.GetTableNameForSQL(const TableName: string): string;
begin
if TableName.Contains(' ') then
Expand Down

0 comments on commit 31dee93

Please sign in to comment.