SurrealDB
SurrealDB Docs Logo

Enter a search query

Navigation
Table of Contents

ALTER FIELD statement

The ALTER FIELD statement is used to change or entirely drop clauses of a defined field on a table.

Statement syntax

SurrealQL Syntax
ALTER FIELD [ IF EXISTS ] ON [ TABLE ] @table [ DROP TYPE | DROP FLEXIBLE | DROP READONLY | DROP VALUE | DROP ASSERT | DROP DEFAULT | DROP COMMENT | DROP REFERENCE | FLEXIBLE | READONLY | REFERENCE | TYPE @type | VALUE @value | ASSERT @expression | DEFAULT [ ALWAYS ] @expression | [ PERMISSIONS [ NONE | FULL | FOR select @expression | FOR create @expression | FOR update @expression | FOR delete @expression ] ] COMMENT @string | ]

Examples

As ALTER FIELD contains the same clauses available in a DEFINE FIELD statement, be sure to see that page for more examples.

Here is one example in which the name field is defined for a record user:

DEFINE FIELD name ON user TYPE string;

Later on, a database-wide parameter is defined to disallow certain user names. This can be followed up with an ALTER FIELD statement to add the ASSERT clause to it.

DEFINE PARAM $DISALLOWED_NAMES VALUE ["Lord British", "Lord Blackthorn"]; ALTER FIELD name ON user ASSERT $value NOT IN $DISALLOWED_NAMES; CREATE user SET name = "Lord British";
Output
"Found 'Lord British' for field `name`, with record `user:yn4yttkg5w683q2937bq`, but field must conform to: $value NOTINSIDE $DISALLOWED_NAMES""

See also