位置: 编程技术 - 正文

SQL2005CLR函数扩展 - 关于山寨索引(sqlldr 函数)

编辑:rootadmin
本文只是一个山寨试验品,思路仅供参考. --------------------------------------------------------------------------------原理介绍:索引建立 目录结构划分方案也只是很简易的实现了一下,通过unicode把任意连续的两个字符(中文或英文)分为4个字节来做四层目录,把索引的内容对应的主关键字(主要为了使用sql索引和唯一性)作为文件名,两个字符在索引内容中的位置作为文件后缀来存储.文件本身为0字节,不保存任何信息.比如一条数据 "pk","山寨索引" 山寨索引 四个字的unicode为[0]: [1]: [2]: [3]: [4]: [5]: [6]: [7]: 那么对应的文件结构为../////pk .0../////pk .1../////pk .2索引使用 比如搜索"寨索引 " 则搜索 "../////" 目录下的所有文件,然后根据 pk .1的文件后缀名1,去看 ../////pk.2文件是否存在.依次类推,最后返回一个结果集. --------------------------------------------------------------------------------实用性具体的实用性还有待验证.这只是实现了精确的like搜索,而不能做常见搜索引擎的分词效果.另外海量数据重建索引的性能也是面临很严峻的问题,比如cpu负载和磁盘io负载.关于windows一个目录下可以保持多少个文件而不会对文件搜索造成大的性能损失也有待评估,不过这个可以考虑根据主键的文件名hash来增加文件目录深度降低单一目录下的文件数量.--------------------------------------------------------------------------------演示效果实现了针对test标的name和caption两个字段作索引搜索. -- 设置和获取索引文件根目录 --select dbo.xfn_SetMyIndexFileRoot('d:/MyIndex') --select dbo.xfn_GetMyIndexFileRoot() -- 建立测试环境 go create table test( id uniqueidentifier , name nvarchar ( ), caption nvarchar ( )) insert into test select top 3 newid (), ' 我的索引 ' , ' 测试 ' from sysobjects insert into test select top 3 newid (), ' 我的测试 ' , ' 索引 ' from sysobjects insert into test select top 3 newid (), ' 测试索引 ' , ' 测试索引 ' from sysobjects insert into test select top 3 newid (), ' 我的索引 ' , ' 索引 ' from sysobjects create index i_testid on test( id) -- 建立索引文件 declare @t int select @t= dbo. xfn_SetKeyForMyIndex( id, 'testIndex' , name + ' ' + caption) from test -- 查询数据 select a.* from test a, dbo. xfn_GetKeyFromMyIndex( '测试 索引 我的' , 'testIndex' ) b where a. id= b. pk/* 0CEA-DF-A-A8E5-BD5FEED 我的索引 测试 2DDB-CD3F-4F-BB4A-F 我的索引 测试 8CA6C3-F-C-BA-CEAE3E 我的索引 测试 CBF1-FB1F-FB-8A-ECEAD3E5 我的测试 索引 8BBFCC-9DBB-4FCB-B2EB-DEDD5F 我的测试 索引 8BD-8E--A-CDF1FA0A 我的测试 索引 */ --drop table test --------------------------------------------------------------------------------clr代码如下:编译为MyFullIndex.dll--------------------------------------------------------------------------------部署的sql脚本如下--drop function dbo.xfn_SetMyIndexFileRoot --drop function dbo.xfn_GetMyIndexFileRoot --drop function dbo.xfn_GetKeyFromMyIndex --drop function dbo.xfn_SetKeyForMyIndex --drop assembly MyFullIndex --go CREATE ASSEMBLY MyFullIndex FROM 'd:/SQLCLR/MyFullIndex.dll' WITH PERMISSION_SET = UnSAFE; -- go -- 索引搜索 CREATE FUNCTION dbo. xfn_GetKeyFromMyIndex ( @word nvarchar ( max ), @indexName nvarchar ( )) RETURNS table ( pk nvarchar ( )) AS EXTERNAL NAME MyFullIndex. UserDefinedFunctions. GetIndex go -- 索引建立 CREATE FUNCTION dbo. xfn_SetKeyForMyIndex ( @pk nvarchar ( ), @indexName nvarchar ( ), @word nvarchar ( max )) RETURNS int AS EXTERNAL NAME MyFullIndex. UserDefinedFunctions. SetIndex go -- 获取索引文件根目录 CREATE FUNCTION dbo. xfn_GetMyIndexFileRoot () RETURNS nvarchar ( max ) AS EXTERNAL NAME MyFullIndex. UserDefinedFunctions. GetRoot go -- 设置索引文件根目录(默认目录为 d:/myindex ) CREATE FUNCTION dbo. xfn_SetMyIndexFileRoot ( @FileRoot nvarchar ( max )) RETURNS bit AS EXTERNAL NAME MyFullIndex. UserDefinedFunctions. SetRoot go

推荐整理分享SQL2005CLR函数扩展 - 关于山寨索引(sqlldr 函数),希望有所帮助,仅作参考,欢迎阅读内容。

SQL2005CLR函数扩展 - 关于山寨索引(sqlldr 函数)

文章相关热门搜索词:sql函数coalesce,sql all函数,sql clr,sqlceiling函数的用法,sql clr,sql clr,sqlceil函数,sqlceil函数,内容如对您有帮助,希望把文章链接给更多的朋友!

SQLCLR函数扩展-繁简转换的实现代码 这个方法比较简单,用Microsoft.VisualBasic命名空间下强大的字符串处理函数就可以了c#代码如下,编译为BigConvertor.dll--------------------------------------------------

SQLCLR函数扩展-解析天气服务的实现 我们可以用CLR获取网络服务来显示到数据库自定函数的结果集中,比如的天气预报

SQLCLR函数扩展-数据导出的实现详解 SQLServer数据导出到excel有很多种方法,比如dts、ssis、还可以用sql语句调用openrowset。我们这里开拓思路,用CLR来生成Excel文件,并且会考虑一些方便操作

标签: sqlldr 函数

本文链接地址:https://www.jiuchutong.com/biancheng/319408.html 转载请保留说明!

上一篇:sql server2005实现数据库读写分离介绍(sql2005使用)

下一篇:SQL2005CLR函数扩展-繁简转换的实现代码(sql cell函数)

  • 房屋用途 居住用房 住宅 区别
  • 安装服务费增值税专票税率多少
  • 普通发票税率1%要交税吗
  • 运输货车折旧计算公式
  • 建筑劳务公司做账分录
  • 公对公退款要交税吗
  • 如何知道一家公司是否可靠
  • 发票上的密码区有什么用
  • 手撕发票怎么领取需要什么证件
  • 计提缴纳印花税怎么做账
  • 投资性房地产的初始计量
  • 记账凭证包括哪些种类
  • 建设单位对施工单位的管理要求
  • 知识产权投资是什么意思
  • 民非企业缴纳社保会计分录
  • 当月取得的进项必须当月勾选吗
  • 保安服务专票是多少税点
  • 餐饮公司如何挣钱
  • 公司没有员工需要缴纳社保吗
  • 固定资产金额小于5000元,可以不一次性税前扣除吗
  • 固定资产入账包括税额吗
  • 会员充值增送如何取消
  • php开发用什么ide
  • 国有土地使用权租赁
  • PHP:session_register_shutdown()的用法_Session函数
  • PHP:pg_select()的用法_PostgreSQL函数
  • 蕨菜的功效与作用及营养价值
  • 国产版忠犬八公观后感
  • 挂靠公司收费几个点
  • chrome浏览器清除数据
  • meta最新模型
  • js正则用法
  • ssh远程登录执行命令
  • pwd命令的用法
  • springboot自动配置的注解
  • 哪些费用发票可以抵扣企业所得税
  • javascrapt
  • 销项税比进项税多怎么办
  • 创立教育培训机构之前的准备工作
  • 金蝶财务软件系统要求
  • 织梦DedeCMS默认文件夹重命名
  • 三险一金的专项扣除标准
  • mongodb reactive
  • 招待客人有什么讲究
  • 公积金个人缴纳和公司缴纳比例
  • 税金及附加需不需要计提
  • 税控系统技术维护费的申报抵扣方法
  • 企业法人股权转让要交什么税
  • 退货给谁
  • 外地预缴税款如何查询
  • 销售退回的会计分录 预计负债
  • 非营利机构如何申请
  • 房地产企业销售商品房增值税税率
  • 空调的折旧年限是多少年的
  • 无票收入怎么报增值税申报表
  • 卸载软件怎么彻底删掉
  • windows server 2008下一些设置技巧及优化经验总结
  • mac怎么自己定制
  • WINDOWS命令行为什么删除速度很快
  • ssh可防止什么攻击
  • movie是什么文件
  • 怎么调用windows api
  • opengl绘制地面
  • jquery实现简洁文件上传表单样式
  • android自定义控件入门与实战
  • perl和shell的区别
  • js获取指定元素
  • unity3d官方案例
  • jQuery EasyUI tree 使用拖拽时遇到的错误小结
  • pythonjam怎么用
  • jQuery实现的指纹扫描效果实例(附演示与demo源码下载)
  • jquery点击按钮切换图片
  • jQuery animate和CSS3相结合实现缓动追逐效果附源码下载
  • 税务举报电话号码
  • 城建税教育费附加怎么做分录
  • 安徽省电子税务局怎么添加办税人员
  • 不动产租赁和经营租赁税率是多少
  • 发票被暂停了严重吗
  • 深圳土地增值税清算规程
  • 地税局开发票流程?
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设