Libraries.Data.Database.QueryResult Documentation
The QueryResult class allows the user to iterate through a result given back from a database query. The result set that is returned from a query can be huge depending on the amount of data on the database so the default method of going through a result is iterate through it row by row rather than return all data at once.
Example Code
use Libraries.Data.Database.Database
use Libraries.Data.Database.Find
use Libraries.Data.Database.QueryResult
use Libraries.Data.Database.QueryMetaData
Database database
database:Connect("localhost", "myDatabase", "user", "SuperSecret456")
Find find
find:AddColumn("itemName")
find:AddColumn("quantity")
find:AddColumn("price")
find:SetTable("orders")
QueryResult result = database:Find(find)
QueryMetaData meta = result:GetQueryMetaData()
integer size = meta:GetSize()
repeat while result:HasNext()
output "row: "
result:Next()
i = 0
repeat while i < size
text value = result:GetText(i)
output value + ", "
i = i + 1
end
output ""
end
Inherits from: Libraries.Language.Object
Actions Documentation
Compare(Libraries.Language.Object object)
This action compares two object hash codes and returns an integer. The result is larger if this hash code is larger than the object passed as a parameter, smaller, or equal. In this case, -1 means smaller, 0 means equal, and 1 means larger. This action was changed in Quorum 7 to return an integer, instead of a CompareResult object, because the previous implementation was causing efficiency issues.
Parameters
- Libraries.Language.Object: The object to compare to.
Return
integer: The Compare result, Smaller, Equal, or Larger.
Example
Object o
Object t
integer result = o:Compare(t) //1 (larger), 0 (equal), or -1 (smaller)
Equals(Libraries.Language.Object object)
This action determines if two objects are equal based on their hash code values.
Parameters
- Libraries.Language.Object: The to be compared.
Return
boolean: True if the hash codes are equal and false if they are not equal.
Example
use Libraries.Language.Object
use Libraries.Language.Types.Text
Object o
Text t
boolean result = o:Equals(t)
GetBoolean(integer column)
This action returns a column from the current row as an boolean. This action grabs a column by position.
Parameters
- integer column: The position of the column to return
Return
boolean: Returns the column value as an boolean
Example
use Libraries.Data.Database.Database
use Libraries.Data.Database.Find
use Libraries.Data.Database.QueryResult
Database database
database:Connect("localhost", "myDatabase", "user", "SuperSecret456")
Find find
find:AddColumn("itemName")
find:AddColumn("quantity")
find:AddColumn("in_stock")
find:SetTable("orders")
QueryResult result = database:Find(find)
repeat while result:HasNext()
result:Next()
output result:GetBoolean(2)
end
GetBoolean(text column)
This action returns a column from the current row as a boolean. This action grabs a column by name.
Parameters
- text column: The name of the column to return
Return
boolean: Returns the column value as a boolean
Example
use Libraries.Data.Database.Database
use Libraries.Data.Database.Find
use Libraries.Data.Database.QueryResult
Database database
database:Connect("localhost", "myDatabase", "user", "SuperSecret456")
Find find
find:AddColumn("itemName")
find:AddColumn("quantity")
find:AddColumn("in_stock")
find:SetTable("orders")
QueryResult result = database:Find(find)
repeat while result:HasNext()
result:Next()
output result:GetBoolean("in_stock")
end
GetDateTime(integer column)
This action returns a column from the current row as an DateTime. This action grabs a column by position.
Parameters
- integer column: The position of the column to return
Return
Libraries.System.DateTime: Returns the column value as an DateTime
Example
use Libraries.Data.Database.Database
use Libraries.Data.Database.Find
use Libraries.Data.Database.QueryResult
Database database
database:Connect("localhost", "myDatabase", "user", "SuperSecret456")
Find find
find:AddColumn("itemName")
find:AddColumn("quantity")
find:AddColumn("added")
find:SetTable("orders")
QueryResult result = database:Find(find)
repeat while result:HasNext()
result:Next()
output result:GetDateTime(2)
end
GetDateTime(text column)
This action returns a column from the current row as a DateTime. This action grabs a column by name.
Parameters
- text column: The name of the column to return
Return
Libraries.System.DateTime: Returns the column value as a DateTime
Example
use Libraries.Data.Database.Database
use Libraries.Data.Database.Find
use Libraries.Data.Database.QueryResult
Database database
database:Connect("localhost", "myDatabase", "user", "SuperSecret456")
Find find
find:AddColumn("itemName")
find:AddColumn("quantity")
find:AddColumn("added")
find:SetTable("orders")
QueryResult result = database:Find(find)
repeat while result:HasNext()
result:Next()
output result:GetBoolean("added")
end
GetHashCode()
This action gets the hash code for an object.
Return
integer: The integer hash code of the object.
Example
Object o
integer hash = o:GetHashCode()
GetInteger(integer column)
This action returns a column from the current row as an integer. This action grabs a column by position.
Parameters
- integer column: The position of the column to return
Return
integer: Returns the column value as an integer
Example
use Libraries.Data.Database.Database
use Libraries.Data.Database.Find
use Libraries.Data.Database.QueryResult
Database database
database:Connect("localhost", "myDatabase", "user", "SuperSecret456")
Find find
find:AddColumn("itemName")
find:AddColumn("quantity")
find:AddColumn("price")
find:SetTable("orders")
QueryResult result = database:Find(find)
repeat while result:HasNext()
result:Next()
output result:GetInteger(1)
end
GetInteger(text column)
This action returns a column from the current row as an integer. This action grabs a column by name.
Parameters
- text column: The name of the column to return
Return
integer: Returns the column value as an integer
Example
use Libraries.Data.Database.Database
use Libraries.Data.Database.Find
use Libraries.Data.Database.QueryResult
Database database
database:Connect("localhost", "myDatabase", "user", "SuperSecret456")
Find find
find:AddColumn("itemName")
find:AddColumn("quantity")
find:AddColumn("price")
find:SetTable("orders")
QueryResult result = database:Find(find)
repeat while result:HasNext()
result:Next()
output result:GetInteger("quantity")
end
GetNumber(text column)
This action returns a column from the current row as a number. This action grabs a column by name.
Parameters
- text column: The name of the column to return
Return
number: Returns the column value as a number
Example
use Libraries.Data.Database.Database
use Libraries.Data.Database.Find
use Libraries.Data.Database.QueryResult
Database database
database:Connect("localhost", "myDatabase", "user", "SuperSecret456")
Find find
find:AddColumn("itemName")
find:AddColumn("quantity")
find:AddColumn("price")
find:SetTable("orders")
QueryResult result = database:Find(find)
repeat while result:HasNext()
result:Next()
output result:GetNumber("price")
end
GetNumber(integer column)
This action returns a column from the current row as an number. This action grabs a column by position.
Parameters
- integer column: The position of the column to return
Return
number: Returns the column value as an number
Example
use Libraries.Data.Database.Database
use Libraries.Data.Database.Find
use Libraries.Data.Database.QueryResult
Database database
database:Connect("localhost", "myDatabase", "user", "SuperSecret456")
Find find
find:AddColumn("itemName")
find:AddColumn("quantity")
find:AddColumn("price")
find:SetTable("orders")
QueryResult result = database:Find(find)
repeat while result:HasNext()
result:Next()
output result:GetNumber(2)
end
GetQueryMetaData()
This action returns metadata related to the query result. The metadata has information about the returned columns such as names, types, and how many were returned. Note that the metadata can only tell you how many columns in the result not how many rows.
Return
Libraries.Data.Database.QueryMetaData: Returns the QueryMetaData of this QueryResult
Example
use Libraries.Data.Database.Database
use Libraries.Data.Database.Find
use Libraries.Data.Database.QueryResult
use Libraries.Data.Database.QueryMetaData
Database database
database:Connect("localhost", "myDatabase", "user", "SuperSecret456")
Find find
find:AddColumn("itemName")
find:AddColumn("quantity")
find:AddColumn("price")
find:SetTable("orders")
QueryResult result = database:Find(find)
QueryMetaData meta = result:GetQueryMetaData()
integer size = meta:GetSize()
output "Number of Columns Returned: " + size
GetText(integer column)
This action returns a column from the current row as text. This action grabs a column by position.
Parameters
- integer column: The position of the column to return
Return
text: Returns the column value as text
Example
use Libraries.Data.Database.Database
use Libraries.Data.Database.Find
use Libraries.Data.Database.QueryResult
Database database
database:Connect("localhost", "myDatabase", "user", "SuperSecret456")
Find find
find:AddColumn("itemName")
find:AddColumn("quantity")
find:AddColumn("price")
find:SetTable("orders")
QueryResult result = database:Find(find)
repeat while result:HasNext()
result:Next()
output result:GetText(0)
end
GetText(text column)
This action returns a column from the current row as text. This action grabs a column by name.
Parameters
- text column: The name of the column to return
Return
text: Returns the column value as text
Example
use Libraries.Data.Database.Database
use Libraries.Data.Database.Find
use Libraries.Data.Database.QueryResult
Database database
database:Connect("localhost", "myDatabase", "user", "SuperSecret456")
Find find
find:AddColumn("itemName")
find:AddColumn("quantity")
find:AddColumn("price")
find:SetTable("orders")
QueryResult result = database:Find(find)
repeat while result:HasNext()
result:Next()
output result:GetText("itemName")
end
HasNext()
This action returns true if there is another row in the query result to iterate to.
Return
boolean: Returns true if there another row in this QueryResult. If there is then Next() will move this QueryResult to the next row.
Example
use Libraries.Data.Database.Database
use Libraries.Data.Database.Find
use Libraries.Data.Database.QueryResult
Database database
database:Connect("localhost", "myDatabase", "user", "SuperSecret456")
Find find
find:AddColumn("itemName")
find:AddColumn("quantity")
find:AddColumn("price")
find:SetTable("orders")
QueryResult result = database:Find(find)
boolean hasResult = result:HasNext()
Next()
This action moves the QueryResult to the next row. A QueryResult only allows for grabbing columns from one row at a time so while iterating through a whole set of a result this action is used when a user wants to move on to the next row.
Example
use Libraries.Data.Database.Database
use Libraries.Data.Database.Find
use Libraries.Data.Database.QueryResult
Database database
database:Connect("localhost", "myDatabase", "user", "SuperSecret456")
Find find
find:AddColumn("itemName")
find:AddColumn("quantity")
find:AddColumn("price")
find:SetTable("orders")
QueryResult result = database:Find(find)
repeat while result:HasNext()
result:Next()
output "row found"
end
On this page
Variables TableAction Documentation- Compare(Libraries.Language.Object object)
- Equals(Libraries.Language.Object object)
- GetBoolean(integer column)
- GetBoolean(text column)
- GetDateTime(integer column)
- GetDateTime(text column)
- GetHashCode()
- GetInteger(integer column)
- GetInteger(text column)
- GetNumber(text column)
- GetNumber(integer column)
- GetQueryMetaData()
- GetText(integer column)
- GetText(text column)
- HasNext()
- Next()