Interact with table data in a ServiceNow instance

  • Release version: Zurich
  • Updated July 31, 2025
  • 3 minutes to read
  • Summarize
    Summarized using AI
    This content was generated using new OpenAI-powered functionality. Results are provided on an as is basis and are not guaranteed to be accurate or complete.

    Summary of Interact with table data in a ServiceNow instance

    This content explains how ServiceNow customers can interact with table data in their ServiceNow instance using the Mobile SDK. It details two primary APIs for accessing and manipulating data: theNowTableService()API, which directly interfaces with the REST Table API, and theNowGraphQLService()API, which leverages GraphQL queries against the REST GraphQL API. These APIs enable CRUD operations on ServiceNow tables while respecting user authorization and access controls.

    Show full answer Show less

    Key Features

    • NowGraphQLService API: Allows construction and execution of GraphQL queries to interact with one or multiple tables in a single call. Ideal for complex queries involving multiple tables. Requires user authorization.
    • NowTableService API: Provides methods for CRUD operations on individual table records via REST Table API. Supports dot-walking on reference fields (e.g., retrieving user names from reference fields). Enforces Access Control Lists (ACLs) to ensure data security and proper authorization.
    • Singleton SdkManager class: Demonstrated approach to create and reuse instances of NowTableService and NowGraphQLService efficiently within an application using dependency injection (e.g., Dagger/Hilt).
    • Practical code examples: Shows how to initialize services, execute queries to retrieve published knowledge base articles with GraphQL, and fetch active customer service cases using NowTableService with filters and pagination.

    What You Can Expect

    • Seamless and secure interaction with ServiceNow table data from mobile or other client applications through the Mobile SDK.
    • Flexibility to perform both simple and complex data queries and operations depending on your needs by choosing between REST Table API or GraphQL API.
    • Respect for ServiceNow's robust security model, ensuring users only access data they are authorized for.
    • Improved developer experience with provided helper classes and code samples to facilitate API integration and reduce setup complexity.

    The Mobile SDK enables you to interact with data in tables that reside on your ServiceNow instance. You can interact with this data through the ServiceNow REST Table API using the NowTableService() API that directly calls the REST interface, or through the NowGraphQLService() API that executes a specified GraphQL query against the REST GraphQL API.

    If you want to return data from multiple tables within a single call, you will need to use the NowGraphQLService() API. If you need to interact with ServiceNow REST APIs other than the Table API, see Interact with the public REST API on a ServiceNow instance.

    Using NowGraphQLService to interact with ServiceNow tables

    The NowGraphQLService class provides methods that enable you to construct and execute GraphQL queries on a specified table within your ServiceNow instance if the logged in user has the proper authorization. You can define all CRUD operations within your GraphQL query.

    The following example shows how to import the NowData framework and then initialize a NowGraphQLService object that you can then use to interact with tables in your ServiceNow instance.
    /**
     * Helper class used to handle different Now service instances.
     */
    @Singleton
    class SdkManager @Inject constructor() {
    
        private var nowGraphQLService: NowGraphQLService? = null
    
        /**
         * Create the NowGraphQLService once in the lifetime of the application inside the Application class or another manager class
         * that will be injected into other classes via dagger/hilt.
         * NowGraphQLService should be created after initializing the NowSDK
         */
        suspend fun getNowGraphQLService(): NowGraphQLService? {
            if (nowGraphQLService != null) return nowGraphQLService
    
            return NowDataSDK.makeGraphQLService(URL("https://instance-name.service-now.com")).getOrThrow()
                .also { this.nowGraphQLService = it }
        }
    }
    This example shows how to obtains published KB articles using a GraphQL query.
    suspend fun loadList() = withContext(Dispatchers.IO) {
        val kbArticlesQuery = """
        { 
            GlideRecord_Query {
                kb_knowledge(queryConditions: "active=true^ORDERBYpublishedDESC"
                pagination:{ limit: 10, offset: 0 }) {
                    _results {
                        sys_id { value },
                        number { displayValue },
                        short_description { displayValue },
                        author { displayValue }
                        published { displayValue }
                    }
                }
            }
         }
     """
        val graphQLService = sdkManager.getNowGraphQLService()
    
        //graphQLService?.graphQLRequest(kbArticlesQuery)?.execute() can also be used
        graphQLService?.graphQLRequest(kbArticlesQuery)?.enqueue(
            { response ->
                response.body?.let {
                    val resultString = String(it)
                }
    
            }, { nowDataError ->
                //handle error
            })
    }

    Using NowTableService to interact with ServiceNow tables

    The NowTableService class provides methods to perform CRUD operations on the records in tables that reside on your ServiceNow instance. Through this interface you can directly access any of the records within any ServiceNow table for which the logged in user is authorized. NowTableService supports dot-walking for reference fields. For example, if a table contains a reference to the User table, the dot-walked value user.name returns the name of the user.

    When returning the requested data, all applicable Access Control Lists (ACLs) are applied to the data, which may result in fewer results than expected, or authorization errors if the authenticated user does not have access rights to the specified table.

    The following example shows how to import the NowData framework and then initialize a NowTableServce object that you can then use to interact with ServiceNow instance tables.
    /**
     * Helper class used to handle different Now service instances. It has an application scope or is Singleton
     */
    @Singleton
    class SdkManager @Inject constructor() {
    
        private var nowTableService: NowTableService? = null
    
        /**
         * Create the NowTableService once in the lifetime of the application inside the Application class or another manager class
         * that will be injected into other classes via dagger/hilt.
         * NowTableService should be created after initializing the NowSDK
         */
        suspend fun getNowTableService(): NowTableService? {
            if (nowTableService != null) return nowTableService
    
            return NowDataSDK.makeTableService(URL("https://instance-name.service-now.com")).getOrThrow()
                .also { this.nowTableService = it }
        }
     }    
    
    
    suspend fun loadCases() = withContext(Dispatchers.IO) {
        val tableService = sdkManager.getNowTableService()
    
        //configure what data to pass back
        val fetchConfiguration =  FetchConfiguration(Filter("active=true"), 10)
    
        val response = runCatching {
            tableService?.records(
                "sn_customerservice_case",
                fetchConfiguration
            )?.execute()
        }
    
        if (response.isSuccess) {
            val resultString = response.getOrNull()?.body?.let { String(it) }
        } else {
            //handle unsuccessful result
        }
    }

    For additional code examples using the available NowTableService methods, refer to the NowTableService API documentation.