SQL Server中的text类型字段要如何查询?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL Server中的text类型字段要如何查询?相关的知识,希望对你有一定的参考价值。

当SQL查询条件包括text类型时,总是报错。
如……where abc="xxxx"
当abc字段是char或varchar类型时,可正常查询。
但当abc字段是text类型时,就无法查询了。
请大侠指教一下。

补充说明:我知道如果通过其它方法,比如改abc类型为varchar可以实现。
但我很想知道text类型的字段要如何查询?

Text类型使用 一般的 Select 查询是不行的,因为它是大二进制存储。存储方式是不一样的。

如果你使用的编程语言是PB的话,则可以使用:
SELECTBLOB RestOfSelectStatement USING TransactionObject ;
专门用于提取Text和image类型的数据

如果是T-SQL,则要使用 READTEXT
READTEXT table.column text_ptr offset size [ HOLDLOCK ]

具体的你可查看相关帮助文档
参考技术A 你好!错误应该是:

数据类型 text 和 varchar 在 equal to 运算符中不兼容。

有一个转换函数不知道你用过了没?

select test_test from test where cast(test_test as varchar)='三国演义'

呵呵!行不行咯!

望好好学习,天天向上!
参考技术B ....一句话, 不应用双引号,要用单引号。 参考技术C char 和 varchar 的长度是可以改变的,
你可以随便制定长度;

nvarchar比较常用;

可以这样解决:
你在sql server 中改变text类型为nvarchar类型,
这种类型很长用,注意指定
nvarchar类型的最大长度,不要小于 text规定的长度就行了;本回答被提问者采纳
参考技术D 你可以通过其它字段来查询这个text类型的字段啊。

SQL Server 2000中查询表名,列名及字段类型

经常碰到一些忘记表名称的情况,此时只记得个大概,此时可通过查询系统表Sysobjects找到所要的表名,如要查找包含用户的表名,可通过以下SQL语句实现, 

Select * 
From sysobjects 
Where name like ‘%user%‘

如果知道列名,想查找包含有该列的表名,可加上系统表syscolumns来实现,如想查找列名中包含有user的所有表名,可通过以下SQL语句来实现 
Select * 
From sysobjects s 
Where Exists( 
Select * 
From syscolumns 
Where ID = s.ID and name like ‘%user%‘
)

查看所有表名:
select    name    from    sysobjects    where    type=‘U‘

查询表的所有字段名:
Select name from syscolumns Where ID=OBJECT_ID(‘表名‘)

select * from information_schema.tables
select * from information_schema.views
select * from information_schema.columns

查看所有表名:
select    name    from    MSysObjects    where    type=1    and    flags=0

MSysObjects是系统对象,默认情况是隐藏的。通过工具、选项、视图、显示、系统对象可以使之显示出来。 

1.按姓氏笔画排序: 
Select * From TableName Order By CustomerName Collate Chinese_PRC_Stroke_ci_as 

2.分页SQL语句 
select * from(select (row_number() OVER (ORDER BY tab.ID Desc)) as rownum,tab.* from 表名 As tab) As t where rownum between 起始位置 And 结束位置 

3.获取当前数据库中的所有用户表 
select * from sysobjects where xtype=‘U‘ and category=0 

4.获取某一个表的所有字段 
select name from syscolumns where id=object_id(‘表名‘) 

5.查看与某一个表相关的视图、存储过程、函数 
select a.* from sysobjects a, syscomments b where a.id = b.id and b.text like ‘%表名%‘ 

6.查看当前数据库中所有存储过程 
select name as 存储过程名称 from sysobjects where xtype=‘P‘ 

7.查询用户创建的所有数据库 
select * from master..sysdatabases D where sid not in(select sid from master..syslogins where name=‘sa‘) 
或者 
select dbid, name AS DB_NAME from master..sysdatabases where sid <> 0x01 

8.查询某一个表的字段和数据类型 
select column_name,data_type from information_schema.columns 
where table_name = ‘表名‘ 

9.使用事务 
在使用一些对数据库表的临时的SQL语句操作时,可以采用SQL SERVER事务处理,防止对数据操作后发现误操作问题 
开始事务 
Begin tran 
Insert Into TableName Values(…) 
SQL语句操作不正常,则回滚事务。 
回滚事务 
Rollback tran 
SQL语句操作正常,则提交事务,数据提交至数据库。 
提交事务 
Commit tran 
10. 按全文匹配方式查询 
字段名 LIKE N‘%[^a-zA-Z0-9]China[^a-zA-Z0-9]%‘ 
OR 字段名 LIKE N‘%[^a-zA-Z0-9]China‘ 
OR 字段名 LIKE N‘China[^a-zA-Z0-9]%‘ 
OR 字段名 LIKE N‘China 

11.计算执行SQL语句查询时间 
declare @d datetime 
set @d=getdate() 
select * from SYS_ColumnProperties select [语句执行花费时间(毫秒)]=datediff(ms,@d,getdate()) 

12、说明:几个高级查询运算词 
A: UNION 运算符 
UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出一个结果表。当 ALL 随 UNION 一起使用时(即 UNION ALL),不消除重复行。两种情况下,派生表的每一行不是来自 TABLE1 就是来自 TABLE2。 
B: EXCEPT 运算符 
EXCEPT 运算符通过包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重复行而派生出一个结果表。当 ALL 随 EXCEPT 一起使用时 (EXCEPT ALL),不消除重复行。 
C: INTERSECT 运算符 
INTERSECT 运算符通过只包括 TABLE1 和 TABLE2 中都有的行并消除所有重复行而派生出一个结果表。当 ALL 随 INTERSECT 一起使用时 (INTERSECT ALL),不消除重复行。








































































以上是关于SQL Server中的text类型字段要如何查询?的主要内容,如果未能解决你的问题,请参考以下文章

sqlserver 如何获得所有数据库名 如何获得已知数据库所有表名 和 已知表明获得所有字段名和字段类型

sql server 2000将一个表的某个字段数据导入另一个表的某个字段中

在sql server 数据库字段中如何加入回车符和换行符?

sqlserver中如何写查询语句

SQL sever 2000 数据库 字段类型疑问

sql查询 自定义类型中某字段类型