How to Use Lucene.NET with Windows Azure SQL Database
http://social.technet.microsoft.com/wiki/contents/articles/2367.how-to-use-lucene-net-with-windows-azure-sql-database.aspx
How to Use Lucene.NET with Windows Azure SQL Database










Table of Contents
- Summary
- Lucene.NET
- The Azure Library for Lucene.NET
- Using Lucene.NET to index SQL Database
- References
Summary
Lucene.NET is a .NET implementation of the Lucene full-text search engine. This article describes how you can use Lucene.NET to index text data stored in Windows Azure SQL Database, and then perform searches against that data.
NOTE: This does not provide an integrated full-text search experience like the full-text search in SQL Server. Lucene.NET is an external process that is queried separately from SQL Database.
NOTE: This article relies on the Azure Library for Lucene.NET (https://azuredirectory.codeplex.com/ ) to store the Lucene.NET catalog in a Windows Azure storage blob.
Prerequisites
- Windows Azure account (offers and purchasing information at http://www.microsoft.com/windowsazure/offers/default.aspx
)
- Visual Studio 2010
- Lucene.NET (http://lucenenet.apache.org/
, both binary and source project are available)
- Azure Library for Lucene.NET (https://azuredirectory.codeplex.com/
)
To use the Azure Library for Lucene.NET and Lucene.NET from a Visual Studio project, you must add a reference to both the AzureDirectory project or assembly, and the Lucerne.NET project or assembly. You must also add the following using statements to your project: using Lucene.Net; using Lucene.Net.Store; using Lucene.Net.Index; using Lucene.Net.Search; using Lucene.Net.Documents; using Lucene.Net.Util; using Lucene.Net.Analysis; using Lucene.Net.Analysis.Standard; using Lucene.Net.Search; using Lucene.Net.QueryParsers; using Lucene.Net.Store.Azure;
Lucene.NET
Lucene.NET is a .NET implementation of Lucene (http://lucene.apache.org/ ) and provides full-text indexing and search of documents. Documents are composed of multiple fields and do not have a predefined schema. When performing a query against the index, you can search across multiple fields within a document. Lucene.NET doesn't directly integrate with SQL Database; instead you must perform a query against a database and construct a Document from the results, which is then cataloged by Lucene.Net. For more information on Lucene.NET, see http://lucenenet.apache.org/
.
The Azure Library for Lucene.NET
This library allows you to expose blob storage as a Lucene.NET.Store.Directory object, which Lucene.NET uses as persistent storage for its catalog. More information on the Azure Library for Lucene.NET, as well as the latest version, can be found on the project homepage at https://azuredirectory.codeplex.com/ .
The current version of the Azure Library (as of 22 May 2013) may require modification before using it in your solution. Specifically:
- It may launch a the Visual Studio project conversion wizard when launched.
- The reference to Microsoft.WindowsAzure.Storage may need to be deleted and recreated to point to the most recent version of the assembly.
- There are several Debug.WriteLine statements that should be converted to Trace.write or another member of the Trace class as documented at http://msdn.microsoft.com/en-us/library/ff966484.aspx
. If you are not interested in diagnostic output, you can simply remove the Debug.WriteLine statements.
Using the Library
The following code creates an AzureDirectory object and uses it as a parameter when creating the IndexWriter:
AzureDirectory azureDirectory =
new
AzureDirectory(
CloudStorageAccount.FromConfigurationSetting(
"Microsoft.WindowsAzure.Plugins.Diagnostics.ConnectionString"
),
"TestCatalog"
);
IndexWriter indexWriter =
new
IndexWriter(azureDirectory,
new
StandardAnalyzer(),
true
);
Using Lucene.NET to index SQL Database
As mentioned previously, Lucene.NET is not integrated directly with SQL Database and is based on indexing 'documents' that contain multiple fields. In order to index data from SQL Database, you must query the database and create a new Document object for each row. Individual columns can then be added to the Document. The following code illustrates querying a SQL Database that contains information on individual bloggers, and then adding the ID and Bio column information to the Lucene index using an IndexWriter and Document:
// Create the AzureDirectory against blob storage and create a catalog named 'Catalog'
AzureDirectory azureDirectory=
new
AzureDirectory(CloudStorageAccount.FromConfigurationSetting(
"Microsoft.WindowsAzure.Plugins.Diagnostics.ConnectionString"
),
"Catalog"
);
IndexWriter indexWriter =
new
IndexWriter(azureDirectory,
new
StandardAnalyzer(),
true
);
indexWriter.SetRAMBufferSizeMB(10.0);
indexWriter.SetUseCompoundFile(
false
);
indexWriter.SetMaxMergeDocs(10000);
indexWriter.SetMergeFactor(100);
// Create a DataSet and fill it from SQL Database
DataSet ds =
new
DataSet();
using
(SqlConnection sqlCon =
new
SqlConnection(sqlConnString))
{
sqlCon.Open();
SqlCommand sqlCmd =
new
SqlCommand();
sqlCmd.Connection = sqlCon;
sqlCmd.CommandType = CommandType.Text;
// Only get the minimum fields we need; Bio to index, Id so search results
// can look up the record in SQL Database
sqlCmd.CommandText =
"select Id, Bio from bloggers"
;
SqlDataAdapter sqlAdap =
new
SqlDataAdapter(sqlCmd);
sqlAdap.Fill(ds);
}
if
(ds.Tables[0] !=
null
)
{
DataTable dt = ds.Tables[0];
if
(dt.Rows.Count > 0)
{
foreach
(DataRow dr
in
dt.Rows)
{
// Create the Document object
Document doc =
new
Document();
foreach
(DataColumn dc
in
dt.Columns)
{
// Populate the document with the column name and value from our query
doc.Add(
new
Field(
dc.ColumnName,
dr[dc.ColumnName].ToString(),
Field.Store.YES,
Field.Index.TOKENIZED));
}
// Write the Document to the catalog
indexWriter.AddDocument(doc);
}
}
}
// Close the writer
indexWriter.Close();
Note: The above sample returns all rows and adds them to the catalog. In a production application you will most likely only want to add new or updated rows.
Searching the Lucene.NET catalog
After you have added documents to the catalog, you can perform a search against them using the IndexSearcher. The following example illustrates how to create perform a search against the catalog for a term contained in the 'Bio' field and return the Id of that result:
// Create the AzureDirectory for blob storage
AzureDirectory azureDirectory =
new
AzureDirectory(CloudStorageAccount.FromConfigurationSetting(
"Microsoft.WindowsAzure.Plugins.Diagnostics.ConnectionString"
),
"Catalog"
);
// Create the IndexSearcher
IndexSearcher indexSearcher =
new
IndexSearcher(azureDirectory);
// Create the QueryParser, setting the default search field to 'Bio'
QueryParser parser =
new
QueryParser(
"Bio"
,
new
StandardAnalyzer());
// Create a query from the Parser
Query query = parser.Parse(searchString);
// Retrieve matching hits
Hits hits = indexSearcher.Search(query);
// Loop through the matching hits, retrieving the document
for
(
int
i = 0; i < hits.Length(); i++)
{
//Retrieve the string value of the 'Id' field from the
//hits.Doc(i) document.
TextBox_Results.Text +=
"Id: "
+ hits.Doc(i).GetField(
"Id"
).StringValue()+
"\n"
;
}
Based on the Id, you can perform a query against SQL Database to return additional fields from the matching record.
References
- https://azuredirectory.codeplex.com/
- http://www.logiclabz.com/c/create-lucene-index-in-c-for-given-sql-stored-procedure.aspx
- http://lucene.apache.org/
- http://lucenenet.apache.org/
- http://www.ifdefined.com/blog/post/2009/02/Full-Text-Search-in-ASPNET-using-LuceneNET.aspx
- http://blogs.msdn.com/b/windows-azure-support/archive/2010/11/01/how-to-use-lucene-net-in-windows-azure.aspx
How to Use Lucene.NET with Windows Azure SQL Database的更多相关文章
- [Windows Azure] Guidelines for Connecting to Windows Azure SQL Database
Guidelines for Connecting to Windows Azure SQL Database 6 out of 12 rated this helpful - Rate this t ...
- [Windows Azure] Development Considerations in Windows Azure SQL Database
Development Considerations in Windows Azure SQL Database 3 out of 5 rated this helpful - Rate this t ...
- [Windows Azure] Windows Azure SQL Database library
Microsoft Windows Azure SQL Database extends SQL Server capabilities to the cloud. SQL Database offe ...
- [Windows Azure] Getting Started with Windows Azure SQL Database
In this tutorial you will learn the fundamentals of Windows Azure SQL Database administration using ...
- 使用SQL Database Migration Wizard把SQL Server 2008迁移到Windows Azure SQL Database
本篇体验使用SQL Database Migration Wizard(SQLAzureMW)将SQL Server 2008数据库迁移到 Azure SQL Database.当然,SQLAzure ...
- [转]Azure 表存储和 Windows Azure SQL Database - 比较与对照
本文转自:https://msdn.microsoft.com/library/azure/jj553018 更新时间: 2014年10月 作者:Valery Mizonov 和 Seth Manhe ...
- [Windows Azure] Getting Started with Windows Azure SQL Data Sync
Getting Started with Windows Azure SQL Data Sync In this tutorial, you learn the fundamentals of Win ...
- 使用SSMS 2014将本地数据库迁移到Azure SQL Database
使用SQL Server Management Studio 2014将本地数据库迁移到Azure SQL Database的过程比较简单,在SSMS2014中,有一个任务选项为“将数据库部署到Win ...
- [Windows Azure] Create and use a reporting service in Windows Azure SQL Reporting
Create and use a reporting service in Windows Azure SQL Reporting In this tutorial you will learn ab ...
随机推荐
- loadrunner --global schedule设置
- 位段(bitfield)
struct { unsigned int fieldA : 4 ; unsigned int fieldB : 2 ; unsigned int ...
- Android_Activity生命周期
通过前面一段时间的学习,我们很清楚我们的一系列操作都离不开的一个东西,就是我们的activity .接下来我们对 Activity 进行系统的总结. Activity 的四种基本状态 1.运行态(Ru ...
- 百度音乐API抓取
百度音乐API抓取 前段时间做了一个本地音乐的播放器 github地址,想实现在线播放的功能,于是到处寻找API,很遗憾,不是歌曲不全就是质量不高.在网上发现这么一个APIMRASONG博客,有“获取 ...
- Java基础之OOP
1. 类(类型)于对象 (1)面向过程的开发于面向对象开发的区别: 面向过程更重视流程化以及功能的开发,简单点来讲,就是按照固定的模式一步步按部就班的进行,最终达成一个功能的实现.这种模式叫做面向过程 ...
- LeetCode之Largest Rectangle in Histogram浅析
首先上题目 Given n non-negative integers representing the histogram's bar height where the width of each ...
- ECharts-基于Canvas,纯Javascript图表库,提供直观,生动,可交互,可个性化定制的数据可视化图表
ECharts http://ecomfe.github.com/echarts 基于Canvas,纯Javascript图表库,提供直观,生动,可交互,可个性化定制的数据可视化图表.创新的拖拽重计算 ...
- 微信小程序 wx.getUserInfo 解密 C# 代码
花了6小时,弄出来的代码.网上的是PHP代码 public static string DecodeUserInfo(string raw, string signature,string encry ...
- AD账号创建日期、最近一次登录时间、最近一次重置密码时间查询
一:查询此AD域内所有用户的创建日期 Get-ADuser -filter * -Properties * | Select-Object Name,SID, Created,PasswordLas ...
- 第四十章 微服务CICD(2)- jenkins(war版)
一.下载 官网下载war包,放在tomcat下的webapps下, 第一章 tomcat安装与启动 第二章 部署war包到tomcat jenkins:2.19.1版本. 二.修改编码为utf-8 在 ...