NHibernate Framework - 1.0
Extension Id
com.castsoftware.dotnet.nhibernate
What’s new?
See NHibernate Framework - 1.0 - Release Notes for more information.
Description
This extension provides support for NHibernate Framework and Fluent NHibernate Framework.
In what situation should you install this extension?
If your C# application uses the NHibernate/Fluent NHibernate Framework and you want to view these object types and their links, then you should install this extension.
Technology support
Component | Version | Supported | Supported Technology |
---|---|---|---|
NHibernate Framework | 2.0 to 5.4 | C# | |
Fluent NHibernate Framework | 2.0 to 3.0 | C# |
AIP Core compatibility
AIP Core release | Supported |
---|---|
8.3.x |
Function Point, Quality and Sizing support
This extension provides the following support:
- Function Points (transactions): a green tick indicates that OMG Function Point counting and Transaction Risk Index are supported
- Quality and Sizing: a green tick indicates that CAST can measure size and that a minimum set of Quality Rules exist
Function Points (transactions) | Quality and Sizing |
---|---|
✔️ | ❌ |
Download and installation instructions
For .NET applications using NHibernate, the extension will be automatically installed by CAST Console. This is in place since October 2023.
For upgrade, if the Extension Strategy is not set to Auto update, you can manually install the extension using the Application - Extensions interface.
What results can you expect?
Objects
Icon | Type Description | When is this object created? |
---|---|---|
NHibernate Entity | Created when an entity is found in hbm xml file or ClassMap is being inherited in the Map class | |
NHibernate Entity Operation | Created and used when CRUD operation is performed on NHibernate Entity | |
|
NHibernate SQL Query | Created for each SQL query found and resolved in an NHibernate method call |
|
NHibernate HQL Query |
Created for each HQL query found and resolved in an NHibernate method call |
|
NHibernate Unknown SQL Query | Created when the query could not be resolved in an NHibernate method call |
|
NHibernate Unknown Entity |
Created and used when the entity could not be resolved |
|
NHibernate Unknown Entity Operation | Used when CRUD operation is performed and Entity could not be resolved |
Links
Link Type | Caller type | Callee type | NHibernate API's Supported |
---|---|---|---|
callLink
|
C# Method | NHibernate Entity Operation
|
ISession APIs |
callLink | C# Method | NHibernate SQL Query / NHibernate HQL Query |
ICriteria APIsISession APIsIQuery APIsAdoNet APIsEngine APIs |
useLink | NHibernate HQL Query | NHibernate Entity operation |
ISession APIsIQuery APIsAdoNet APIsEngine APIs |
useLink | NHibernate SQL Query / NHibernate HQL Query |
Table, View | Created by SQL Analyzer when DDL source files are analyzed |
callLink | NHibernate SQL Query / NHibernate HQL Query |
Procedure | |
useLink | NHibernate Entity Operation | Table, View | Created by WBS when DDL source files are analyzed by SQL Analyzer |
callLink | NHibernate Entity Operation | Procedure | |
useLink | NHibernate SQL Query / NHibernate HQL Query |
Missing Table | Created by Missing tables and procedures for .Net extension when the object is not analyzed. |
callLink | NHibernate SQL Query / NHibernate HQL Query |
Missing Procedure |
Code Examples
Select Operation
Using hbm.xml file
public static void studentGet(NHibernate.ISession session)
{
var stdnt = session.Get<Student>(1);
Console.WriteLine("Retrieved by ID");
Console.WriteLine("{0} \t{1} \t{2}", stdnt.ID,
stdnt.FirstMidName, stdnt.LastName);
}
Using Fluent Nhibernate mapping
using FluentNHibernate.Mapping;
namespace NHibernateExample
{
class ParentMap : ClassMap<Parent>
{
public ParentMap()
{
Id(x => x.ID);
Map(x => x.FirstMidName);
Map(x => x.LastName);
Table("ParentFluent");
}
}
}
public static void parentUpdate(NHibernate.ISession session)
{
var parentGet = session.Get<Parent>(1);
Console.WriteLine("Retrieved by ID");
Console.WriteLine("{0} \t{1} \t{2}", parentGet.ID, parentGet.FirstMidName, parentGet.LastName);
Console.WriteLine("Update the last name of ID = {0}", parentGet.ID);
parentGet.LastName = "Donald";
session.Update(parentGet);
Console.WriteLine("\nFetch the complete list again\n");
}
Update Operation
Update
public static void studentUpdate(NHibernate.ISession session, Student stdntGet)
{
session.Update(stdntGet);
Console.WriteLine("\nFetch the complete list again\n");
}
Delete Operation
Delete
public static void studentDelete(NHibernate.ISession session, Student stdntDel)
{
session.Delete(stdntDel);
Console.WriteLine("\nFetch the complete list again\n");
}
Query String
Execute Update
public static void deleteDataUsingQuery(ISession session)
{
IQuery query = session.CreateQuery("DELETE FROM Customer WHERE Id = '12345'");
query.ExecuteUpdate();
}
ExecuteNonQuery Using ADOSQLCommandSet
public static void updateDataUsingADOSQLCommandSetNonQuery(ISession session, CancellationToken cancellationToken)
{
MySqlClientSqlCommandSet mySqlClientSqlCommandSet = new MySqlClientSqlCommandSet(5);
DbCommand dbCommand = session.Connection.CreateCommand();
for (int i = 0; i < 5; i++)
{
dbCommand.CommandText = "INSERT INTO Customer (CustomerID, Name) VALUES (" +i.ToString()+ ", 'John Doe')";
mySqlClientSqlCommandSet.Append(dbCommand);
}
mySqlClientSqlCommandSet.ExecuteNonQuery();
}
ExecuteNonQuery Using EngineNonQuery
public static void updateDataUsingEngineNonQuery(ISession session, CancellationToken cancellationToken)
{
IBatcher batcher = (IBatcher)session.CreateQueryBatch();
batcher.BatchSize = 5;
DbCommand dbCommand = session.Connection.CreateCommand();
dbCommand.CommandText = "INSERT INTO Customer (CustomerID, Name) VALUES (1, 'John Doe')";
batcher.ExecuteNonQuery(dbCommand);
}
ExecuteNonQuery Using ADO
public static void updateDataUsingADONonQuery(ISession session, CancellationToken cancellationToken)
{
DbCommand dbCommand = session.Connection.CreateCommand();
dbCommand.CommandText = "INSERT INTO Customer (CustomerID, Name) VALUES (1, 'John Doe')";
AbstractBatcher abstractBatcher = (AbstractBatcher)session.CreateQueryBatch();
abstractBatcher.ExecuteNonQuery(dbCommand);
}
ExecuteReader Using ADO
public static void updateDataUsingADOReader(ISession session, CancellationToken cancellationToken)
{
DbCommand dbCommand = session.Connection.CreateCommand();
dbCommand.CommandText = "SELECT * FROM Parent p WHERE p.ID IN( SELECT ID FROM Teacher WHERE ID = '12345')";
AbstractBatcher abstractBatcher = (AbstractBatcher)session.CreateQueryBatch();
DbDataReader reader = abstractBatcher.ExecuteReader(dbCommand);
}
ExecuteReader Using Engine
public static void updateDataUsingEngineReader(ISession session, CancellationToken cancellationToken)
{
IBatcher batcher = (IBatcher)session.CreateQueryBatch();
batcher.BatchSize = 5;
DbCommand dbCommand = session.Connection.CreateCommand();
dbCommand.CommandText = "UPDATE Employee SET FirstMidName = 'Robert' WHERE ID = '12345'";
DbDataReader reader = batcher.ExecuteReader(dbCommand);
}
Criteria
public static void studentSelect(NHibernate.ISession session)
{
var cc = session.CreateCriteria<Student>();
var students = cc.List<Student>();
foreach (var student in students)
{
Console.WriteLine("{0} \t{1} \t{2}", student.ID,
student.FirstMidName, student.LastName);
}
}
Query and QueryOver
public static void fetchTouristUsingQuery(NHibernate.ISession session)
{
var tourists = session.Query<Tourist>().Where(c => c.FirstMidName.StartsWith("H"));
foreach (var tourist in tourists.ToList())
{
Console.WriteLine(tourist);
}
}
public static void fetchVendorUsingQueryOver(NHibernate.ISession session)
{
var vendors = session.QueryOver<Vendor>().Where(x => x.LastName == "Laverne");
foreach (var vendor in vendors.List())
{
Console.WriteLine(vendor);
}
}
Named Queries
Named Queries are generated with the help of hbm.xml files relating to the entity. Below is an example of one such hbm.xml file :
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2">
<class name="Employee" table="employees">
<id name="Id" column="id">
<generator class="native" />
</id>
<property name="Name" column="name" />
<property name="Age" column="age" />
<property name="Salary" column="salary" />
<sql-query name="GetEmployeesWithSalaryGreaterThan">
SELECT *
FROM employees
where Salary > :minSalary
</sql-query>
<query name="GetEmployeesWithSalaryLessThan">
SELECT *
FROM Employee
where :minSalary > Salary
</query>
</class>
</hibernate-mapping>
Named SQL Queries
Named SQL Queries
public static void fetchEmployeeUsingNamedSQLQuery(NHibernate.ISession session)
{
var query = session.GetNamedQuery("GetEmployeesWithSalaryGreaterThan");
query.SetParameter("minSalary", 50000m);
var results = query.List<Employee>();
foreach (var employee in results)
{
Console.WriteLine("{0}: {1}", employee.Name, employee.Salary);
}
}
Named HQL Queries
Named HQL Queries
public static void fetchEmployeeUsingNamedQuery(NHibernate.ISession session)
{
var query = session.GetNamedQuery("GetEmployeesWithSalaryLessThan");
query.SetParameter("minSalary", 50000m);
var results = query.List<Employee>();
foreach (var employee in results)
{
Console.WriteLine("{0}: {1}", employee.Name, employee.Salary);
}
}