MSSQL 对比数据类型text和varchar / navchar(xxx)

今天在查询数据表中的一个字段,数据类型为TEXT。

SELECT TOP 10 * FROM Table1
  WHERE TEXT1 = ‘12321’;

错误提示:数据类型 text 和 varchar 在 equal to 运算符中不兼容。

C#中不管是TEXT或VARCHAR还有NAVCHAR都会对应String类型,但在数据库中却不能直接对他们直接进行比较。

修改SQL语句如下:

使用CONVERT(字段类型, 字段名称)

SELECT TOP 10 * FROM table1
  WHERE CONVERT(VARCHAR, col1) = '12321';

也可以使用LIKE

SELECT TOP 10 * FROM table1
  WHERE col1 LIKE '12321';

  

posted @ 2015-04-29 19:00  蓝天_野菜  阅读(847)  评论(0编辑  收藏  举报