SQL Server中的text类型字段要如何查询?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL Server中的text类型字段要如何查询?相关的知识,希望对你有一定的参考价值。
当SQL查询条件包括text类型时,总是报错。
如……where abc="xxxx"
当abc字段是char或varchar类型时,可正常查询。
但当abc字段是text类型时,就无法查询了。
请大侠指教一下。
补充说明:我知道如果通过其它方法,比如改abc类型为varchar可以实现。
但我很想知道text类型的字段要如何查询?
如果你使用的编程语言是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将一个表的某个字段数据导入另一个表的某个字段中