MS SQL Server: Rename Relationships
An existing relationship can be renamed as follows:
- Console
- CLI
- API
Renaming Local Relationships
- Head to
Data -> [table-name] -> Relationships
in the Console - Click on the
Rename
option for the relationship in question.
data:image/s3,"s3://crabby-images/d1811/d18117dfc90a1caf5c1808fa4ab561cf4418d288" alt="Fill the relationship details"
- This will open up a pop-up widget which will allow you to rename and save the relationship
data:image/s3,"s3://crabby-images/efb71/efb71bc1f4c8ecff69337a73ce5f8c804961cb80" alt="Fill the relationship details"
Renaming Remote Relationships
Remote relationships cannot be renamed. They have to dropped and created again with the new name.
You can rename a relationship by changing the relationship name in the tables.yaml
file inside the metadata
directory:
- table:
schema: public
name: articles
object_relationships:
- name: author
using:
foreign_key_constraint_on: author_id
- table:
schema: public
name: authors
Apply the Metadata by running:
hasura metadata apply
You can rename a relationship by using the mssql_rename_relationship Metadata API:
POST /v1/metadata HTTP/1.1
Content-Type: application/json
X-Hasura-Role: admin
{
"type": "mssql_rename_relationship",
"args": {
"source": "<db_name>",
"table": "articles",
"name": "article_details",
"new_name": "article_detail"
}
}
Note
You might not be allowed to drop a relationship if it has been referenced elsewhere (e.g. in a permissions rule).
In this case you will have to delete the references first, rename the relationship, and then re-add the references.