SQL Server文本和图像函数
文本和图像函数
1、查找特定字符串PATINDEX
语法与字符串的patindex一样。
2、获取文本指针TEXTPTR
SQLServer在存储文本类型(ntext、text)和图像数据类型(image)时,默认情况是与常见的基本数据类型(如char、int等)这样的数据时单独存储的,也就是说,如 果一个表中的字段有基本类型和图像文本类型,那么,在输入数据时,基本类型和图像文件数据并不是保存在同一个页面上,而是分离存储的。分离存储后,那么基本类型数据和文本图像类型数据所在的页面就是通过文本指针建立联系,是一个16字节的二进制类型指针。在基本类型数据页面中存储的就是这些指向数据的指针,这样在需要的时候通过指针来操作文本和图像数据。Textptr函数就可以用于获得文本和图像数据存储的文本指针,这个指针获得后就可以被操作文本和图像数据的函数(wrutetext、readtext和updatetext等)进行操作。如果没有有效的指针,文本和图像函数是无法操作数据的。
语法结构:
textptr( column )
这里的column就是表中的文本和图像数据列(text、ntext和image)名称。
返回值:
varbinary类型16字节指针。
配合使用的函数:
在编写含有TEXTPTR函数的T-SQL代码时,下表所示的函数经常被使用。
格式 | 说明 |
patindex('%pattern%',expression) | 返回字符串在text或ntext列中的字符位置 |
datalength(expression) | 返回text、ntext和image列中数据的长度 |
set textsize |
返回对select语句所返回的text、ntext或image数据的限制(字节数)。settextsize 0表示不限制。 |
substring(text_column,start,length) | 返回二进制列中又指定的start偏移量和length指定的varchar类型的字符串。字符串的长度硬小于8kb |
3、检测文本指针是否有效TEXTVALID
textvalid函数用于检测文本指针是否有效。
语法结构:
textvalid( 'table.column',text_ptr )
参数说明:
table:表的名称,必须包含
column:表中的二进制数据列(text、ntext和image)名称
text_ptr:要检测的文本指针
返回值:
int,如果指针有效返回1,否则分那会0。
4、读取文本图像列内容READTEXT
readtext函数用于读取文本或图像列的内容,按照指定的偏移量开始读取指定字节数。如果是图像列(image),这样读取的是字节数,而不是现实图像本身。
语法结构:
readtext{ table.column text_ptr offset size } [holdlock]
参数说明:
table:表名称
column:列名称
text_ptr:有效的文本指针,即16字节的binary数据。
offset:开始读取text、image类型数据之前,要跳过的字节数。读取ntext类型数据之前要跳过的字符数。
size:读取的字节数(使用text或image数据类型时)或字符数(使用ntext数据类型时)。如果size为0,则读取4KB数据。
holdlock:使文本值被锁定以进行读取,直到十五结束为止。其他用户可以读取该值,但不能对其进行修改。
返回值:
varchar字符。
示例:以后写
5、写入文本图像列内容WRITETEXT
writetext函数用于向文本或图像写入内容,同时可以选择为最小日志记录,这样写入操作产生的日志写的I/O次数少,对数据库性能影响小。
语法结构:
writetext{ table.column text_ptr } [ with log ] { data }
参数说明:
table:表名称
column:列名称
text_ptr:有效的文本指针,即16字节的binary数据。
with log:由数据库的恢复模式来决定writetext操作产生的日志行为。因为text、ntext、imge类型的数据一般情况下都比较大。比如一幅图片可能上百KB,我们知道一个数据页面的容量是标准的8KB。所以一幅图片很可能就需要几时个甚至更多的数据页面,所以writetext操作所产生的I/O次数是很多的,而过多的I/O次数将影响数据库的性能。该参数的引入是交给数据库的恢复模式来决定的writetext操作将产生的日志行为。当数据库公仔在完全恢复模式时,产生的日志最多,因此对数据库性能的影响也最大。当工作在简单恢复模式时,产生的日志最少。
data:要存储的text、ntext或image类型的数据。writetext以交互方式插入的最大文本长度约为120KB。
6、更新文本图像列内容UPDATETEXT
updatetext函数更新文本或图像列中的内容。与writetext的区别在于该函数可以仅更新列中的一部分,而writetext是更新整个列。
语法结构:
updatetext{ table.name.dest_column_name dest_text_ptr }{ null | insert_offset }{ with log }{ inserted_data | { table.name.src_column_name src_text_ptr } }
语法中的参数说明如下。
table_name:表名称。
dest_column_name:列名称。
dest_text_ptr:有效的文本指针,即16字节的binary数据。
insert_offset:以0为基础的更新其实位置,对于Text或image列,insert_offset是在插入新数据前要从现有列的起点跳过的字节数。对于ntext列,insert_offset是字符数(每个ntext字符占用2个字节)。从此基数为零的起始点开始的现有text、ntext或image数据向右移,为新数据留出空间。值为0表示将新数据插入现有数据的开始处。值为null则将新数据追加到享有数据值后。
delete_length:从insert_offset位置开始、要从现有text、ntext、或image列中删除的数据长度。delete_length值对于text和image列用字节指定,对于 ntext列用字符指定。每个ntext字符占用2个字节。值为0表示不删除数据。值为null则删除现有text或image列中从insert_offset位置开始到末尾的所有数据。
withlog:日子记录由数据库的当前模式决定。
inserted_date:要插入现有text、ntext或image列的insert_offset位置的数据。这是单个char、nchar、varchar、nvarchar、binary、varbinary、text、 ntext或image值。inserted_data可以是文字或变量。
table_name.src_column_name:用作插入数据源的表或text、ntext、image列的名称。
src_text_ptr:指向用作插入数据源的text、ntext或image列的文本指针值,通常使用textptr函数获得。
SQL Server文本和图像函数相关推荐
- Sql Server函数全解三数据类型转换函数和文本图像函数
原文:Sql Server函数全解<三>数据类型转换函数和文本图像函数 一:数据类型转换函数 在同时处理不同数据类型的值时,SQL Server一般会自动进行隐士类型转换.对于数据类型相近 ...
- Excel数字、文本混合列导入SQL Server出现的问题&解决办法
版权声明:转载时请以超链接形式标明文章原始出处和作者信息及本声明 http://annie-out.blogbus.com/logs/60276495.html Excel文件: 序号 姓名 内部电话 ...
- sql server的搜索_在SQL Server中进行全文本搜索
sql server的搜索 介绍 (Introduction) In most cases, we will use clustered and non-clustered indexes to he ...
- 向SQL Server 中导入长文本
向SQL Server 中导入长文本数据(如小说.报告)进行分析时,有一些细节需要注意,这里将流程做一个梳理: 文章目录 以每个段落作为一行进行导入 新建表 导入数据 数据源设置 映射设置 完成 截断 ...
- SQL Server 数据类型(整数、浮点数据、日期与时间数据、文本和图形数据类型、货币数据类型、位数据类型、二进制数据类型)
数据类型: 每个属性来自一个域,他的取值必须是域中的值.在SQL中域的概念用数据类型来实现,定义表的各个属性时需要指明其数据类型及长度. 一:系统数据类型 Sql Server 提供的系统 ...
- Excel 导入 Sql Server出错——“文本被截断,或者一个或多个字符在目标代码页中没有匹配项”错误的解决...
一直在说截断,但是并未发现错误,也修改了映射的长度(证明并无卵用),查了下网上说的解决办法,说是改注册表,,修改方法如下: 如果是:Jet引擎. HKEY_LOCAL_MACHINE\SOFTWARE ...
- 轻松学SQL Server数据库pdf
下载地址:网盘下载 目录: 第1章 数据库与SQL Server 2008 1 1.1 数据库基础 2 1.1.1 数据库的概念 2 1.1.2 数据库模型 2 1.2 什么是关系型数据库 2 1. ...
- sql server编程之 T-SQL函数
T-SQL函数 学习系统函数.行集函数和Ranking函数:重点掌握字符串函数.日期时间函数和数学函数的使用参数以及使用技巧 重点掌握用户定义的标量函数以及自定义函数的执行方法 掌握用户定义的内嵌表值 ...
- SQL Server 函数
一.聚合函数 1.Avg 返回组中值的平均值.空值将被忽略. 2.Binary_checksum 返回按照表的某一行或一组表达式计算出来的二进制校验和值.Binary_checksum可用于检测表中行 ...
最新文章
- Linux文件目录付空,Linux 文件系统
- Linux学习-文件管理(2)
- git 命令简单总结
- 您应该对什么进行单元测试? –测试技术3
- android摄像头的autoFocus-----循环自动聚焦的实现
- 偶然获得2011高校信息化创新征文大赛鼓励奖
- APS计划排程和生产排产系统,包含哪些排程算法?
- fms安装教程 linux_[AS3]linux64下安装FMS5.0的方法
- 找规律万能公式_求各种数学万能公式求一些万能公式,帮助各个喜欢数学的同学,求解方程、列方程、求根、列规律式等等,最好有较详细的用法和解释....
- jQuery fadeIn淡入效果
- 怎样做一个拥有全局观的人
- unique mapped reads
- 数据系统架构-5.实时离线统计系统
- DNF 单机游戏 手机游戏 网络游戏 推荐游戏 TXT 小说 外挂 辅助
- 怎样把游戏从计算机卸载了,电脑桌面上的游戏怎么卸载,电脑桌面上的游戏怎么卸载?...
- 声控门的工作原理与人工智能AI
- Linux与MySql学习之旅(一): 离线安装MySQL和问题解决
- 通用读取Excel文件内容的模板设计
- 《网络安全工程师笔记》 第十四章:渗透简单测试流程
- 工程材料(3.1)钢铁材料