You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I'm using the .NET SDK to retrieve some data based on user input
FormattableStringx=$"RETURN array::at((SELECT * FROM characters WHERE {where} ORDER BY rand() LIMIT 1), 0);";
where can be a combination of different WHERE clauses generated based on the user input.
My problem is that when I use x as input to Query() it returns data that does not match the WHERE clauses.
If x is evaluated to:
RETURN array::at((SELECT*FROM characters WHERE gender ='male'ORDER BY rand() LIMIT1), 0);
and used as input to Query() it will return data for which gender is not male.
Using RawQuery() solves this issue as this seems to be related to how Query() handles the FormattableString input.
Steps to reproduce
// set is just a string which can be any combination of d, m, f, and g.foreach(varcinset){if(cis'd')result|=(1<<0);if(cis'm')result|=(1<<1);if(cis'f')result|=(1<<2);if(cis'g')result|=(1<<3);}stringwhere="gender";string[]genders=["","",""];if(((result>>0)&0x1)is1){if(where.EndsWith("gender"))where =" = 'diverse'";elsewhere =" OR gender = 'diverse'";}if(((result>>1)&0x1)is1){if(where.EndsWith("gender"))where =" = 'male'";elsewhere =" OR gender = 'male'";}if(((result>>2)&0x1)is1){if(where.EndsWith("gender"))where =" = 'female'";elsewhere =" OR gender = 'female'";}FormattableStringquery=$"RETURN array::at((SELECT * FROM characters WHERE {where} ORDER BY rand() LIMIT 1), 0);";try{varres=awaitdb.Query(query);rolled=res.GetValue<Character>(0);}catch(Exceptione){Console.WriteLine(e);return;}
Expected behaviour
Query() should not return any data which does not match the WHERE clauses in the SurrealQL query.
Query is made to interpolate queries while RawQuery exist for scenario where you just pass the plain string query. The first one will interpret variables and replace them with SurrealDB variable when the other one just give the expected string output. Thes particular Query method exist for different reasons, the notable one is to escape variables to avoid SurrealQL injections. This can be mandatory in a frontend client app like a Blazor app. If your code is only used in a server, you can use any of them with RawQuery being the more flexible to use.
So, from the example, this method call:
awaitdb.Query($"RETURN array::at((SELECT * FROM characters WHERE {where} ORDER BY rand() LIMIT 1), 0);");
will output the following query:
RETURN array::at((SELECT*FROM characters WHERE $p0 ORDER BY rand() LIMIT1), 0);
which will then, given the parameter, be interpreted by SurrealDB as:
RETURN array::at((SELECT*FROM characters WHERE"gender = 'male'"ORDER BY rand() LIMIT1), 0);
The WHERE condition becomes a unary operator (checking on a string). It will so check if it is a truthy value. Since it is a non-empty string, it will be evaluated as true. Hence, being completely ignored and returning the whole table.
This happens also because SurrealDB can let you write these types of queries without throwing an error.
So, that explains the behavior of the Query method. To close on this, I can see that you are trying to write expressions by hand. Note that this is indeed the only way to do that currently until #61 is implemented.
Describe the bug
I'm using the .NET SDK to retrieve some data based on user input
where
can be a combination of differentWHERE
clauses generated based on the user input.My problem is that when I use
x
as input toQuery()
it returns data that does not match theWHERE
clauses.If
x
is evaluated to:and used as input to
Query()
it will return data for whichgender
is notmale
.Using
RawQuery()
solves this issue as this seems to be related to howQuery()
handles theFormattableString
input.Steps to reproduce
Expected behaviour
Query()
should not return any data which does not match theWHERE
clauses in the SurrealQL query.SurrealDB version
1.5.4 for linux on x86_64
Package version(s)
Contact Details
No response
Is there an existing issue for this?
Code of Conduct
The text was updated successfully, but these errors were encountered: