开发者社区> 问答> 正文

jdbc执行SqlServer语句提示:不支持“variant”数据类型。

下面是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

展开
收起
宋玉东墙 2019-01-27 15:42:32 5021 0
2 条回答
写回答
取消 提交回答
  • 业余草www.xttblog.com网站站长,CODE大全网站站长,爱分享www.ifxvn.com或www.ndislwf.com网站站长!

    楼上回答的很正确,mssql-jdbc...
    业余草

    2019-07-17 23:27:03
    赞同 1 展开评论 打赏
  • 1.阿里云大学讲师,主讲《微服务Spring Cloud设计与开发实战》《MongoDB高级实战》等课程 2.MongoDB中文社区专家 3.《MongoDB实战》第2版译者 5.吉林大学计算机科学学士、上海交通大学硕士

    升级一下驱动看看,6.1.2版本。
    https://github.com/Microsoft/mssql-jdbc/issues/91

    2019-07-17 23:27:03
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
PolarDB NL2SQL: 帮助您写出准确、优化的SQL 立即下载
SQL Sever迁移PG经验 立即下载
低代码开发师(初级)实战教程 立即下载