2016-12-01 9 views
0

Товарищи! Мне нужна помощь! Я не могу выполнить сценарий SQL Server с драйвером JTDS версии 1.3.1. Подробности ниже.Невозможно выполнить сценарий SQL Server с помощью JTDS 1.3.1

Я попытался удалить некоторые строки SQL-скрипта, но ничего не помогает.

SQL скрипт:

USE [SomeScheme] 
    GO 
    DECLARE @ID int 
    , @Guid nvarchar(50) 
    , @Name nvarchar(250) 
    , @Caption nvarchar(250) 
    , @Description nvarchar(max) 

    SET @Description = NULL; 

SET @Guid = 'EAID_4076F221_3910_4480_B49A_09621E214249'; 
SET @Name = 'datetime'; 
SET @Caption = 'datetime'; 
IF EXISTS(SELECT [Guid] FROM rdf.SimplePropertyTypes WHERE [Guid] = @Guid) 
BEGIN 
SET @ID = (SELECT ID FROM rdf.SimplePropertyTypes WHERE [Guid][email protected]) 
UPDATE rdf.SimplePropertyTypes 
SET Name = @Name 
, Caption = @Caption 
, [Description] = @Description 
WHERE [Guid][email protected] 
END 
ELSE 
BEGIN 
SET @ID = ISNULL((SELECT MAX(ID) FROM rdf.SimplePropertyTypes),0) + 1000 
INSERT INTO rdf.SimplePropertyTypes(ID, [Guid], Name, Caption, [Description]) VALUES 
(@ID, @Guid, @Name, @Caption, @Description); 
END 
SET @Description = NULL 

Java код:

try (final Connection connection = sourceDataSource.getConnection(); 
    final CallableStatement callableStatement = connection.prepareCall(sql)) { 
    callableStatement.executeUpdate(); 
} 

Исключение трассировки стека:

Caused by: java.sql.SQLException: Invalid JDBC escape syntax at line position 68 '=' character expected. 
    at net.sourceforge.jtds.jdbc.SQLParser.mustbe(SQLParser.java:412) 
    at net.sourceforge.jtds.jdbc.SQLParser.callEscape(SQLParser.java:554) 
    at net.sourceforge.jtds.jdbc.SQLParser.escape(SQLParser.java:1009) 
    at net.sourceforge.jtds.jdbc.SQLParser.parse(SQLParser.java:1178) 
    at net.sourceforge.jtds.jdbc.SQLParser.parse(SQLParser.java:165) 
    at net.sourceforge.jtds.jdbc.JtdsPreparedStatement.<init>(JtdsPreparedStatement.java:111) 
    at net.sourceforge.jtds.jdbc.JtdsCallableStatement.<init>(JtdsCallableStatement.java:70) 
    at net.sourceforge.jtds.jdbc.JtdsConnection.prepareCall(JtdsConnection.java:2426) 
    at net.sourceforge.jtds.jdbc.JtdsConnection.prepareCall(JtdsConnection.java:2412) 
    at org.apache.commons.dbcp.DelegatingConnection.prepareCall(DelegatingConnection.java:308) 
    at org.apache.commons.dbcp.PoolingDataSource$PoolGuardConnectionWrapper.prepareCall(PoolingDataSource.java:303) 

Водитель: JTDS 1.3.1

Нужна помощь!

+0

Попробуйте использовать простой 'Statement' объект вместо' CallableStatement'. –

ответ

0

GO не допускается в PreparedStatements, следовательно, ответ:

try (final Connection connection = sourceDataSource.getConnection(); 
      final PreparedStatement preparedStatement = connection.prepareStatement(sql.replaceAll(" GO\n", " "))) { 
    preparedStatement.executeUpdate(); 
} 

 Смежные вопросы

  • Нет связанных вопросов^_^