Book Image

NHibernate 3.0 Cookbook

By : Jason Dentler
Book Image

NHibernate 3.0 Cookbook

By: Jason Dentler

Overview of this book

<p>NHibernate is an innovative, flexible, scalable, and feature-complete open source project for data access. Although it sounds like an easy task to build and maintain database applications, it can be challenging to get beyond the basics and develop applications that meet your needs perfectly.<br /><br />The NHibernate Cookbook explains each feature of NHibernate 3.0 in detail through example recipes that you can quickly apply to your applications. Set yourself free from stored procedures and inline SQL. Quite simply, if you build .NET applications that use databases, this book is for you.<br /><br />The book will take you from the absolute basics of NHibernate through its most advanced features and beyond, showing you how to take full advantage of each concept to quickly create amazing database applications. Beginners will learn several techniques for each of the 4 core NHibernate tasks – mapping, configuration, session &amp; transaction management, and querying – and which techniques fit best with various types of applications. In short, you will be able to build an application using NHibernate. Intermediate level readers will learn how to best implement enterprise application architecture patterns using NHibernate, leading to clean, easy-to-understand code, and increased productivity. In addition to new v3.0 features, advanced readers will learn creative ways to extend NHibernate core, as well as techniques using the NHibernate search, shards, spatial, and validation projects.</p>
Table of Contents (15 chapters)
NHibernate 3.0 Cookbook
Credits
About the Author
About the Reviewers
Preface
Index

Preloading data with SQLite


It is often desirable to preload the database with test data before running tests. In this recipe, I will show you how to quickly load the in-memory database with data from a SQLite file database.

Getting ready

Complete the previous recipe, Fast testing with SQLite in-memory database.

Create a SQLite file database with identical schema, containing test data. This can be accomplished in a number of ways. Perhaps the easiest is to export an in-memory database using SQLiteLoader.ExportData from this recipe.

How to do it...

  1. Add a new class named SQLiteLoader using the following code:

    private static ILog log = LogManager.GetLogger(typeof(SQLiteLoader));
    
    private const string ATTACHED_DB = "asdfgaqwernb";
    
    public void ImportData(
      SQLiteConnection conn,
      string sourceDataFile)
    {
      
      var tables = GetTableNames(conn);
      AttachDatabase(conn, sourceDataFile);
    
      foreach (var table in tables)
      {
        var sourceTable = string.Format("{0}.{1}", 
          ATTACHED_DB, table);
    
    ...