Node.js 无法对位调用方法

Node.js 无法对位调用方法,node.js,sql-server,geospatial,spatial-query,Node.js,Sql Server,Geospatial,Spatial Query,我试图检查两个地理对象是否相交,并删除重叠部分(不在下面的代码段中执行此部分)。请在下面查找代码。这给了我错误 无法对位调用方法 我正在使用mssql库和节点10。我找不到有关此错误的任何信息。我想知道这是一个代码错误还是mssql库的一些问题。如果是,我如何解决这个问题 *****更新****** 它只对STIntersects()给出此错误,对STIntersection()和STDifference工作正常 const sql = require('mssql'); let

我试图检查两个地理对象是否相交,并删除重叠部分(不在下面的代码段中执行此部分)。请在下面查找代码。这给了我错误

无法对位调用方法

我正在使用mssql库和节点10。我找不到有关此错误的任何信息。我想知道这是一个代码错误还是mssql库的一些问题。如果是,我如何解决这个问题

*****更新****** 它只对STIntersects()给出此错误,对STIntersection()和STDifference工作正常

const sql = require('mssql');
        let path1 = `geography::STGeomFromText('POLYGON((-122.358 47.653, -122.348 47.649, -122.348 47.658, -122.358 47.658, -122.358 47.653))', 4326).MakeValid()`;
        let path2 = `geography::STGeomFromText('LINESTRING(-122.360 47.656, -122.343 47.656)', 4326).MakeValid()`;
        let query = `SELECT ${path1}.STIntersects(${path2}).ToString();
        SELECT ${path1}.STIntersection(${path2}).ToString();`;
        let dbConfig = {
            user: 'username',
            password: 'password',
            server: 'localhost',
            database: 'db_name',
            port: port,
            connectionTimeout: 30000,
            requestTimeout: 180000,
            max: 15,
            min: 3,
            idleTimeoutMillis: 30000
        };

        sql.connect(dbConfig, err => {
            if (err)
                throw err;
            console.log('Success');
            queryExecuter();

        });

        let queryExecuter = async () => {
            try {
                let request = new sql.Request();
                let result1 = await request.query(query)

                console.log(result1)
            } catch (err) {
                console.log(err)
                // ... error checks
            }
        }

        sql.on('error', err => {
            console.log(err)
            // ... error handler
        })

基本上,我只是尝试在一个位上调用ToString()函数,该位是StinerSects()的返回类型,在SQL中不受支持/不需要。感谢@Jeroen Mostert消除了这种模糊性。

嗯,是的
.STIntersects()
返回一个
bit
,而
bit
没有方法(T-SQL不是面向对象的语言;方法是例外而不是规则)。此错误由服务器本身返回。从查询中删除
.ToString()
。啊!非常感谢,这很有效。我不知道我在想什么。