首页 \ 问答 \ Hashtable使用哈希?(Hashing used by Hashtable?)

Hashtable使用哈希?(Hashing used by Hashtable?)

Java中的Hashtable实现使用了什么样的哈希方法?


What kind of hashing methodoly is used in Hashtable implementation in Java?


原文:https://stackoverflow.com/questions/4546287
更新时间:2024-01-07 19:01

最满意答案

您需要先根据您的查询创建一个VIEW ,然后为其添加一个全文索引,其中将包含ParentName列。 如果没有正在搜索的列上的全文索引, FREETEXTCONTAINS都不起作用。

像这样的东西应该可以帮助你:

CREATE VIEW ExpectationsView AS
SELECT ExpectationId
    ,ExpectationName
    ,(
       CASE 
          WHEN ExpectationOrganization_OrganizationId IS NOT NULL
                THEN (
                       SELECT OrganizationName
                       FROM Organizations
                       WHERE OrganizationId = ExpectationOrganization_OrganizationId
                       )
          WHEN ExpectationBeneficiary_BeneficiaryId IS NOT NULL
                THEN (
                       SELECT BeneficiaryName
                       FROM Beneficiaries
                       WHERE BeneficiaryId = ExpectationBeneficiary_BeneficiaryId
                       )
          ELSE (
                    SELECT TeamName
                    FROM Teams
                    WHERE TeamId = ExpectationTeam_TeamId
                    )
          END
       ) AS ParentName
FROM Expectations
GO

-- This index is needed for FTS index.
-- Note, I trust ExpectationId column is unique in your SELECT above,
-- if it's not, the below CREATE INDEX will fail and you will need to provide 
-- a new column to your VIEW which will uniquely identify each row, then use 
-- that PK-like column in the below index
CREATE UNIQUE CLUSTERED INDEX PK_ExpectationsView   
    ON ExpectationsView (ExpectationId);  
GO  

CREATE FULLTEXT CATALOG fts_catalog;  
GO  
CREATE FULLTEXT INDEX ON ExpectationsView  
 (
    ExpectationName Language 1033,   
    ParentName Language 1033
 )   
  KEY INDEX PK_ExpectationsView 
      ON fts_catalog;
      WITH (CHANGE_TRACKING = AUTO)
GO  

一旦包含相关列的全文索引存在,您可以在查询中使用FREETEXTCONTAINS

SELECT ExpectationId, ExpectationName, ParentName FROM ExpectationsView
    WHERE FREETEXT(ExpectationName, @Keyword) OR FREETEXT(ParentName, @Keyword)

请注意,上面提供的代码是我的头顶,因为我没有数据模式,因此无法尝试运行它。 但是,它应该给你关于如何进行的一般想法。 HTH。


You need to create a VIEW based on your query first then add a Full-Text index to it which will include the ParentName column. Without the Full-Text index over a column being searched neither FREETEXT nor CONTAINS will work.

Something like that should help you:

CREATE VIEW ExpectationsView AS
SELECT ExpectationId
    ,ExpectationName
    ,(
       CASE 
          WHEN ExpectationOrganization_OrganizationId IS NOT NULL
                THEN (
                       SELECT OrganizationName
                       FROM Organizations
                       WHERE OrganizationId = ExpectationOrganization_OrganizationId
                       )
          WHEN ExpectationBeneficiary_BeneficiaryId IS NOT NULL
                THEN (
                       SELECT BeneficiaryName
                       FROM Beneficiaries
                       WHERE BeneficiaryId = ExpectationBeneficiary_BeneficiaryId
                       )
          ELSE (
                    SELECT TeamName
                    FROM Teams
                    WHERE TeamId = ExpectationTeam_TeamId
                    )
          END
       ) AS ParentName
FROM Expectations
GO

-- This index is needed for FTS index.
-- Note, I trust ExpectationId column is unique in your SELECT above,
-- if it's not, the below CREATE INDEX will fail and you will need to provide 
-- a new column to your VIEW which will uniquely identify each row, then use 
-- that PK-like column in the below index
CREATE UNIQUE CLUSTERED INDEX PK_ExpectationsView   
    ON ExpectationsView (ExpectationId);  
GO  

CREATE FULLTEXT CATALOG fts_catalog;  
GO  
CREATE FULLTEXT INDEX ON ExpectationsView  
 (
    ExpectationName Language 1033,   
    ParentName Language 1033
 )   
  KEY INDEX PK_ExpectationsView 
      ON fts_catalog;
      WITH (CHANGE_TRACKING = AUTO)
GO  

Once the Full-Text index which includes the relevant columns is there you can use FREETEXT or CONTAINS in queries:

SELECT ExpectationId, ExpectationName, ParentName FROM ExpectationsView
    WHERE FREETEXT(ExpectationName, @Keyword) OR FREETEXT(ParentName, @Keyword)

Note, the above code I've provided off the top of my head because I don't have data schema for your case so couldn't try running it. However, it should give you the general idea on how to proceed. HTH.

相关问答

更多

相关文章

更多

最新问答

更多
  • 获取MVC 4使用的DisplayMode后缀(Get the DisplayMode Suffix being used by MVC 4)
  • 如何通过引用返回对象?(How is returning an object by reference possible?)
  • 矩阵如何存储在内存中?(How are matrices stored in memory?)
  • 每个请求的Java新会话?(Java New Session For Each Request?)
  • css:浮动div中重叠的标题h1(css: overlapping headlines h1 in floated divs)
  • 无论图像如何,Caffe预测同一类(Caffe predicts same class regardless of image)
  • xcode语法颜色编码解释?(xcode syntax color coding explained?)
  • 在Access 2010 Runtime中使用Office 2000校对工具(Use Office 2000 proofing tools in Access 2010 Runtime)
  • 从单独的Web主机将图像传输到服务器上(Getting images onto server from separate web host)
  • 从旧版本复制文件并保留它们(旧/新版本)(Copy a file from old revision and keep both of them (old / new revision))
  • 西安哪有PLC可控制编程的培训
  • 在Entity Framework中选择基类(Select base class in Entity Framework)
  • 在Android中出现错误“数据集和渲染器应该不为null,并且应该具有相同数量的系列”(Error “Dataset and renderer should be not null and should have the same number of series” in Android)
  • 电脑二级VF有什么用
  • Datamapper Ruby如何添加Hook方法(Datamapper Ruby How to add Hook Method)
  • 金华英语角.
  • 手机软件如何制作
  • 用于Android webview中图像保存的上下文菜单(Context Menu for Image Saving in an Android webview)
  • 注意:未定义的偏移量:PHP(Notice: Undefined offset: PHP)
  • 如何读R中的大数据集[复制](How to read large dataset in R [duplicate])
  • Unity 5 Heighmap与地形宽度/地形长度的分辨率关系?(Unity 5 Heighmap Resolution relationship to terrain width / terrain length?)
  • 如何通知PipedOutputStream线程写入最后一个字节的PipedInputStream线程?(How to notify PipedInputStream thread that PipedOutputStream thread has written last byte?)
  • python的访问器方法有哪些
  • DeviceNetworkInformation:哪个是哪个?(DeviceNetworkInformation: Which is which?)
  • 在Ruby中对组合进行排序(Sorting a combination in Ruby)
  • 网站开发的流程?
  • 使用Zend Framework 2中的JOIN sql检索数据(Retrieve data using JOIN sql in Zend Framework 2)
  • 条带格式类型格式模式编号无法正常工作(Stripes format type format pattern number not working properly)
  • 透明度错误IE11(Transparency bug IE11)
  • linux的基本操作命令。。。