Photon Server初识(二) ---通过NHibernate 映射数据库
一、下载 NHibernate.dill 官网:https://nhibernate.info

或者通过NuGet下载(详情看上一节)
二、新建一个项目,并引入包


引入包


三、配置(重点)
1、配置xml文件:(1)在项目根目录下新建文件 hibernate.cfg.xml (配置数据库信息)
(2) 新建文件夹 Model,里面新建model文件 DbModel.cs (定义数据库表映射的model)
(3) 新建文件夹Mappings,里面新建文件 DbModel.hbm.xml (配置model和数据库表关联)

2、调整文件属性
(1)、hibernate.cfg.xml属性调整为始终复制
(2)、DbModel.hbm.xml属性调整为嵌入的资源



3、在项目根目录新建文件 hibernate.cfg.xml (名字必须一样)
<?xml version="1.0" encoding="utf-8"?> <hibernate-configuration xmlns="urn:nhibernate-configuration-2.2" >
<session-factory>
<property name="connection.driver_class">NHibernate.Driver.MySqlDataDriver</property> <!-- mysql驱动这里是 MySQL5Dialect, mysql服务版本是5.7(最新版8.1好像链接不上) -->
<property name="dialect">NHibernate.Dialect.MySQL5Dialect</property> <!-- 数据库连接信息 -->
<property name="connection.connection_string">
Server=localhost;Database=webdemo;User Id=root;Password=foto_cj1;
</property> <!-- 调试时是否显示sql语句 -->
<property name="show_sql">true</property> <!-- 有的版本需要添加下面这一项 -->
<!-- <mapping assembly="Nbibernate"/> -->
</session-factory>
</hibernate-configuration>
4、配置model 文件DbModel.cs
namespace Nbibernate.Model
{
public class DbModel
{
//字段跟数据库表列一样
public virtual int Id { get; set; } public virtual string Name { get; set; } public virtual int Age { get; set; }
public virtual string Title { get; set; }
}
}
5、映射文件(models与数据库表关联) DbModel.hbm.xml
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
assembly="Nbibernate"
namespace="Nbibernate.Model"> <class name="DbModel" table="netweb">
<id name="Id" column="id" type="Int32">
<generator class="native" />
</id>
<property name="Name" column="name" type="String" />
<property name="Age" column="age" type="Int32" />
<property name="Title" column="title" type="String" />
</class> </hibernate-mapping>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
assembly="Nbibernate"
namespace="Nbibernate.Model"> assembly 项目名称
namespace 关联的Model文件得包路径
<class name="DbModel" table="netweb">
name model类名
table 关联的数据库表名
<id name="Id" column="id" type="Int32">
<generator class="native" />
</id> name Model的字段名, column 关联表的列名
assembly 项目名称在这里查看:

四、测试数据库连接,在Program.cs中添加测试代码
namespace Nbibernate
{
internal class Program
{
public static void Main(string[] args)
{ var configuration = new Configuration();
configuration.Configure(); //解析hibernate.cfg配置文件
configuration.AddAssembly("Nbibernate"); //解析 映射文件 DbModel.hbm.xml (有的版本在映射文件添加了,该处可以省略) ISessionFactory sessFa = null;
ISession session = null;
// ITransaction transaction = null; //可以打开一个事务,处理多个操作时
try
{
sessFa = configuration.BuildSessionFactory();
session = sessFa.OpenSession(); //打开一个跟数据库的回话
// transaction = session.BeginTransaction(); //打开一个事务 var msg = new DbModel {Name = "Kiddd1111", Age = , Title = "Logeg"};
var msg2 = new DbModel {Name = "L2222", Age = , Title = "tiles"}; session.Save(msg);
session.Save(msg2);
// transaction.Commit(); //提交事务 Console.WriteLine("ddddddd");
}
catch (Exception e)
{
Console.WriteLine(e);
throw;
}
finally
{
// transaction?.Dispose(); // 关闭事务 -- c#的新语法 ,如果不为null,则关闭
session?.Close();
sessFa?.Close();
} Console.WriteLine("dddddddd");
Console.ReadKey();
}
}
}
运行代码,数据库查看结果。
参考文件:https://blog.csdn.net/qq_40323256/article/details/82914340
参考视频:https://www.bilibili.com/video/av35109390/?p=12
Photon Server初识(二) ---通过NHibernate 映射数据库的更多相关文章
- Photon Server初识(一) ---C#链接MySql
环境: 1.MAC电脑,JetBrains Rider编辑器 2.本地MySql5.7 (开始安装8.1发现使用 NHibernate 映射链接不上) 一.新建工程 二.引入dll包(MySQL.Da ...
- Photon Server初识(四) --- 部署自己的服务Photon Server
准备工作: 1.一台 window 虚拟机(本机是window也行) 2.下载SDK : https://www.photonengine.com/zh-CN/sdks#server 一:SDK介绍 ...
- Photon Server初识(三) ---ORM映射改进
一:新建一些管理类, 二.实现每个管理类 (1)NHibernateHelper.cs 类,管理数据库连接 using NHibernate; using NHibernate.Cfg; namesp ...
- Photon Server初识(六) --- 客户端与服务端消息传递
前一章客户端与服务端连接成功,现在需要前后端进行数据传递. 一.前端发送消息.在项目Scripts目录中新建脚本 TestSer.cs.并挂载到相机上 二.客户端发送数据给服务端.编辑客户端代码 Te ...
- Photon Server初识(五) --- 客户端连接服务端
准备:Unity开开发IDE. 一.新建Unity3D项目 导入包,在资源下新建目录 Plugins .在之前解压的SDK目录 lib中找到 Photon3Unity3D.dll,拖到新建的目前下 二 ...
- 一、初识MySQL数据库 二、搭建MySQL数据库(重点) 三、使用MySQL数据库 四、认识MySQL数据库的数据类型 五、操作MySQL数据库的数据(重点)
一.初识MySQL数据库 ###<1>数据库概述 1. 数据库 长期存储在计算机内的,由组织的可共享的数据集合 存储数据的仓库 文件 ...
- 咱就入个门之NHibernate映射文件配置(二)
上一篇主要介绍了NHibernate映射文件的基础配置,这篇我们介绍下NHibernate的一对多及多对一配置(文中我直接使用双向关联,即一和多两端都配置,开发中可以只使用一端),同时略带介绍下NHi ...
- Photon Server 实现注册与登录(一) --- Hibernate整合到项目中
本系列实现目的:基于Photon Server实现注册于登录 一.拷贝Nbibernate项目的文件到MyGamerServer项目中. 二.数据库新建表,结构如下 三.修改文件名和配置 (1).将拷 ...
- NHibernate 映射基础(第三篇) 简单映射、联合主键
NHibernate 映射基础(第三篇) 简单映射.联合主键 NHibernate完全靠配置文件获取其所需的一切信息,其中映射文件,是其获取数据库与C#程序关系的所有信息来源. 一.简单映射 下面先来 ...
随机推荐
- CF892D—Gluttony(思维,好题)
http://codeforces.com/contest/892/problem/D D. Gluttony You are given an array a with n distinct int ...
- codeforces#1165 F2. Microtransactions (hard version) (二分+贪心)
题目链接: https://codeforces.com/contest/1165/problem/F2 题意: 需要买$n$种物品,每种物品$k_i$个,每个物品需要两个硬币 每天获得一个硬币 有$ ...
- Codeforces 126B. Password(KMP,DP)
Codeforces 126B. Password 题意:一个字符串,找出最长的子串t,它既是前缀又是后缀,还出现在中间.输出t,不存在则输出Just a legend. 思路:利用KMP算法处理出n ...
- [JZOJ6346]:ZYB和售货机(拓扑+基环内向森林)
题目描述 可爱的$ZYB$来到一个售货机前. 售货机里有一共有$N(\leqslant 10^5)$个物品,每个物品有$A_i$个.自然,还有$N$个购买按钮.正常情况下,按下第$i$个按钮,需要支付 ...
- solr系列之solr-5.5.5 window单机版jdk-1.7 tomcat8安装
一.Solr5.5.5.Tomcat8-x64.jdk-1.7-64单机部署 1.准备安装包,下载solr和tomcat的安装,直接解压即可(上篇一提供solr的下载路径) 2.在Solr5之前都还存 ...
- Leetcode题目分类整理
一.数组 8) 双指针 ---- 滑动窗口 例题: 3. Longest Substring Without Repeating Characters 描述:Given a string, find ...
- Linux服务器操作
Linux关于服务器的操作(root权限) 1. 查看服务器版本信息 cat /etc/redhat-release 2.将Windows上文件通过xshell传到Linux服务器 查找系统自带软件包 ...
- 用Python写一个将Python2代码转换成Python3代码的批处理工具
之前写过一篇如何在windows操作系统上给.py文件添加一个快速处理的右键功能的文章:<一键将Python2代码自动转化为Python3>,作用就是为了将Python2的文件升级转换成P ...
- git send-email时报错:Client host rejected: cannot find your hostname 如何处理?
1. 先找出ip对应的域名 dig +short -x <your ip> 2. 如果第1步没有输出,那么需要将hostname与ip绑定,如:hostname为jello,那么是往/et ...
- CSS 优先级法则
样式的优先级 多重样式(Multiple Styles):如果外部样式.内部样式和内联样式同时应用于同一个元素,就是使多重样式的情况. 一般情况下,优先级如下: (外部样式)External styl ...
