SQLServerException: 不能对 nvarchar 调用方法

org.apache.ibatis.exceptions.PersistenceException: 
### Error querying database.  Cause: com.microsoft.sqlserver.jdbc.SQLServerException: 不能对 nvarchar 调用方法。
### The error may exist in zzu/qg/mybatis/mapper/UserMapper.xml
### The error may involve zzu.qg.mybatis.mapper.UserMapper.findUserByInfo-Inline
### The error occurred while setting parameters
### SQL: select * from [user]    WHERE  user.sex = ?
### Cause: com.microsoft.sqlserver.jdbc.SQLServerException: 不能对 nvarchar 调用方法。
    at org.apache.ibatis.exceptions.ExceptionFactory.wrapException(ExceptionFactory.java:23)
    at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:107)
    .....
Caused by: com.microsoft.sqlserver.jdbc.SQLServerException: 不能对 nvarchar 调用方法。
    at com.microsoft.sqlserver.jdbc.SQLServerException.makeFromDatabaseError(SQLServerException.java:216)
    at com.microsoft.sqlserver.jdbc.SQLServerStatement.getNextResult(SQLServerStatement.java:1515)
    at com.microsoft.sqlserver.jdbc.SQLServerPreparedStatement.doExecutePreparedStatement(SQLServerPreparedStatement.java:404)
    ......
    报的sql语句出错,

我就进到数据库里面 ### SQL: select * from [user]    WHERE  user.sex = ? 测试sql语句

需要将 user.sex改为[user].sex

可以使用SQL Server的CLR集成功能来实现发送HTTP请求。CLR集成是SQL Server提供的一种机制,允许开发人员使用.NET编程语言编写存储过程、函数和触发器等托管代码。 以下是一个简单的示例,演示如何使用CLR集成发送HTTP请求: 1. 创建一个C#类库项目,添加以下代码: ``` using System; using System.Data.SqlTypes; using System.Net; public class HttpHelper { [Microsoft.SqlServer.Server.SqlFunction] public static SqlString SendHttpRequest(SqlString url) { try { WebClient client = new WebClient(); string response = client.DownloadString(url.ToString()); return new SqlString(response); } catch (Exception ex) { return new SqlString(ex.Message); } } } ``` 2. 在项目中添加引用 System.Data和 System.Data.SqlServer。 3. 在项目属性中,选择“生成”选项卡,将目标框架设置为.NET Framework 4.0或更高版本。选择“生成”菜单,生成项目。 4. 将DLL文件添加到SQL Server中。在SQL Server Management Studio中,右键单击“数据库”节点,选择“新建查询”。 5. 输入以下命令,创建一个程序集: ``` CREATE ASSEMBLY HttpHelper FROM 'C:\Path\To\HttpHelper.dll' WITH PERMISSION_SET = SAFE; ``` 6. 创建一个存储过程,调用CLR函数: ``` CREATE PROCEDURE GetHttpData (@url NVARCHAR(200)) AS EXTERNAL NAME HttpHelper.[HttpHelper].SendHttpRequest; ``` 7. 调用存储过程: ``` EXEC GetHttpData 'http://www.example.com'; ``` 执行以上命令,即可通过SQL Server调用CLR函数发送HTTP请求,并返回响应结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值