This is an automated email from the ASF dual-hosted git repository.

chengzhang pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/shardingsphere.git


The following commit(s) were added to refs/heads/master by this push:
     new 0ddf849c9df fix:Support for the OPENDATASOURCE function in INSERT 
statements (#36093)
0ddf849c9df is described below

commit 0ddf849c9dfacc9144a172e851a4aeac08a7ae16
Author: cxy <[email protected]>
AuthorDate: Tue Jul 29 14:09:07 2025 +0800

    fix:Support for the OPENDATASOURCE function in INSERT statements (#36093)
---
 .../src/main/antlr4/imports/sqlserver/BaseRule.g4  |  2 +-
 .../statement/SQLServerStatementVisitor.java       | 17 ++++++++++++-
 .../parser/src/main/resources/case/dml/insert.xml  | 28 ++++++++++++++++++++++
 .../main/resources/sql/supported/dml/insert.xml    |  1 +
 4 files changed, 46 insertions(+), 2 deletions(-)

diff --git 
a/parser/sql/dialect/sqlserver/src/main/antlr4/imports/sqlserver/BaseRule.g4 
b/parser/sql/dialect/sqlserver/src/main/antlr4/imports/sqlserver/BaseRule.g4
index b661482ce05..aefc76943c2 100644
--- a/parser/sql/dialect/sqlserver/src/main/antlr4/imports/sqlserver/BaseRule.g4
+++ b/parser/sql/dialect/sqlserver/src/main/antlr4/imports/sqlserver/BaseRule.g4
@@ -465,7 +465,7 @@ openQueryFunction
     ;
 
 rowSetFunction
-    : openRowSetFunction | openQueryFunction
+    : openRowSetFunction | openQueryFunction | openDatasourceFunction
     ;
 
 regularFunction
diff --git 
a/parser/sql/dialect/sqlserver/src/main/java/org/apache/shardingsphere/sql/parser/sqlserver/visitor/statement/SQLServerStatementVisitor.java
 
b/parser/sql/dialect/sqlserver/src/main/java/org/apache/shardingsphere/sql/parser/sqlserver/visitor/statement/SQLServerStatementVisitor.java
index ed5b594f827..f22e72b5bcf 100644
--- 
a/parser/sql/dialect/sqlserver/src/main/java/org/apache/shardingsphere/sql/parser/sqlserver/visitor/statement/SQLServerStatementVisitor.java
+++ 
b/parser/sql/dialect/sqlserver/src/main/java/org/apache/shardingsphere/sql/parser/sqlserver/visitor/statement/SQLServerStatementVisitor.java
@@ -252,6 +252,7 @@ import 
org.apache.shardingsphere.sql.parser.autogen.SQLServerStatementParser.Par
 import 
org.apache.shardingsphere.sql.parser.autogen.SQLServerStatementParser.TryParseFunctionContext;
 import 
org.apache.shardingsphere.sql.parser.autogen.SQLServerStatementParser.TableHintExtendedContext;
 import 
org.apache.shardingsphere.sql.parser.autogen.SQLServerStatementParser.LinkedServerNameContext;
+import 
org.apache.shardingsphere.sql.parser.autogen.SQLServerStatementParser.OpenDatasourceFunctionContext;
 
 import java.util.Collection;
 import java.util.Collections;
@@ -1068,6 +1069,18 @@ public abstract class SQLServerStatementVisitor extends 
SQLServerStatementBaseVi
         return getFunctionSegment(ctx.getStart().getStartIndex(), 
ctx.getStop().getStopIndex(), ctx.OPENQUERY().getText(), getOriginalText(ctx), 
ctx.expr());
     }
     
+    @Override
+    public ASTNode visitOpenDatasourceFunction(final 
OpenDatasourceFunctionContext ctx) {
+        FunctionSegment result = new 
FunctionSegment(ctx.getStart().getStartIndex(), ctx.getStop().getStopIndex(), 
ctx.OPENDATASOURCE().getText(), getOriginalText(ctx));
+        for (ExprContext each : ctx.expr()) {
+            result.getParameters().add((ExpressionSegment) visit(each));
+        }
+        if (null != ctx.tableName()) {
+            result.getParameters().add(new 
LiteralExpressionSegment(ctx.tableName().getStart().getStartIndex(), 
ctx.tableName().getStop().getStopIndex(), ctx.tableName().getText()));
+        }
+        return result;
+    }
+    
     @Override
     public final ASTNode visitRegularFunction(final RegularFunctionContext 
ctx) {
         return getFunctionSegment(ctx.getStart().getStartIndex(), 
ctx.getStop().getStopIndex(), ctx.regularFunctionName().getText(), 
getOriginalText(ctx), ctx.expr());
@@ -1347,8 +1360,10 @@ public abstract class SQLServerStatementVisitor extends 
SQLServerStatementBaseVi
     public ASTNode visitRowSetFunction(final RowSetFunctionContext ctx) {
         if (null != ctx.openRowSetFunction()) {
             return visit(ctx.openRowSetFunction());
-        } else {
+        } else if (null != ctx.openQueryFunction()) {
             return visit(ctx.openQueryFunction());
+        } else {
+            return visit(ctx.openDatasourceFunction());
         }
     }
     
diff --git a/test/it/parser/src/main/resources/case/dml/insert.xml 
b/test/it/parser/src/main/resources/case/dml/insert.xml
index 268e6ae5a85..912bcb576da 100644
--- a/test/it/parser/src/main/resources/case/dml/insert.xml
+++ b/test/it/parser/src/main/resources/case/dml/insert.xml
@@ -4387,4 +4387,32 @@
             </value>
         </values>
     </insert>
+
+    <insert sql-case-id="insert_with_opendatasource_function">
+        <rowset-function text="OPENDATASOURCE('SQLNCLI', 'Data Source= 
&lt;server_name&gt;; Integrated 
Security=SSPI').AdventureWorks2022.HumanResources.Department" 
function-name="OPENDATASOURCE" start-index="12" stop-index="137">
+            <parameter>
+                <literal-expression value="SQLNCLI" start-index="27" 
stop-index="35"/>
+            </parameter>
+            <parameter>
+                <literal-expression value="Data Source= &lt;server_name&gt;; 
Integrated Security=SSPI" start-index="38" stop-index="91"/>
+            </parameter>
+            <parameter>
+                <literal-expression 
value="AdventureWorks2022.HumanResources.Department" start-index="94" 
stop-index="137"/>
+            </parameter>
+        </rowset-function>
+        <columns start-index="139" stop-index="155">
+            <column name="Name" start-index="140" stop-index="143"/>
+            <column name="GroupName" start-index="146" stop-index="154"/>
+        </columns>
+        <values>
+            <value>
+                <assignment-value>
+                    <literal-expression value="Standards and Methods" 
start-index="165" stop-index="188"/>
+                </assignment-value>
+                <assignment-value>
+                    <literal-expression value="Quality Assurance" 
start-index="191" stop-index="209"/>
+                </assignment-value>
+            </value>
+        </values>
+    </insert>
 </sql-parser-test-cases>
diff --git a/test/it/parser/src/main/resources/sql/supported/dml/insert.xml 
b/test/it/parser/src/main/resources/sql/supported/dml/insert.xml
index 8e2ec5a4a3c..4d7f3a41e45 100644
--- a/test/it/parser/src/main/resources/sql/supported/dml/insert.xml
+++ b/test/it/parser/src/main/resources/sql/supported/dml/insert.xml
@@ -157,4 +157,5 @@
     <sql-case id="insert_with_geom_collection_function" value="INSERT INTO t1 
VALUES (GEOMCOLLECTION(POINT(0, 0)))" db-types="MySQL" />
     <sql-case id="insert_select_with_brackets" value="insert into t_order 
(order_id) (select order_id from t_order_item)" db-types="MySQL" />
     <sql-case id="insert_into_four_level_naming" value="INSERT INTO 
MyLinkServer.AdventureWorks2022.HumanResources.Department (Name, GroupName) 
VALUES (N'Public Relations', N'Executive General and Administration');" 
db-types="SQLServer"/>
+    <sql-case id="insert_with_opendatasource_function" value="INSERT INTO 
OPENDATASOURCE('SQLNCLI', 'Data Source= &lt;server_name&gt;; Integrated 
Security=SSPI').AdventureWorks2022.HumanResources.Department (Name, GroupName) 
VALUES (N'Standards and Methods', 'Quality Assurance')" db-types="SQLServer"/>
 </sql-cases>

Reply via email to