jdbc执行sqlserver语句报错,错误为:不支持“variant”数据类型。

歆晨 2019-01-27 03:46:53
下面是sql语句:
SELECT

表名 =case when a .colorder= 1 then d.name else '' end ,

表说明 =case when a .colorder= 1 then isnull(f .value, '') else '' end,

字段序号 =a. colorder,

字段名 =a. name,

标识 =case when COLUMNPROPERTY ( a .id, a.name ,'IsIdentity')= 1 then '√' else '' end ,

主键 =case when exists( SELECT 1 FROM sysobjects where xtype ='PK' and name in (

SELECT name FROM sysindexes WHERE indid in(

SELECT indid FROM sysindexkeys WHERE id = a .id AND colid =a. colid

))) then '√ ' else '' end,

类型 =b. name,

占用字节数 =a. length,

长度 =COLUMNPROPERTY( a.id ,a. name,'PRECISION' ),

小数位数 =isnull( COLUMNPROPERTY(a .id, a.name ,'Scale'), 0),

允许空 =case when a .isnullable= 1 then '√' else '' end,

默认值 =isnull( e.text ,''),

字段说明 =isnull( g.[value] ,'')

FROM syscolumns a

left join systypes b on a. xusertype=b .xusertype

inner join sysobjects d on a. id=d .id and d .xtype= 'U' and d.name <>'dtproperties'

left join syscomments e on a. cdefault=e .id

left join sys. extended_properties g on a.id =g. major_id and a.colid =g. minor_id

left join sys. extended_properties f on d.id =f. major_id and f. minor_id=0

where d .name= 'test'

order by a. id,a .colorder
...全文
689 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
亲爱的Joe 2019-01-27
  • 打赏
  • 举报
回复
你是怎么连接数据库的?开发语言是Java的话,一般都是jdbc连接数据库,jdbc是不支持sql_variant类型的。需要强制转换

81,094

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧