现有环境:
Java JDK1.8
MySQL5.7
【ps】本文是很早前的基于隐马尔科夫模型进行中文词性标注的后续升级完善版,任务就是将之前的写入文件的模型参数写入MySQL
下载Hibernate http://hibernate.org/orm/releases/
下载好后解压,将jpa和required路径下的Jar包全部复制出来到自己创建的lib文件夹
构建的lib
还有:要下载Java连接MySQL的驱动 地址 http://static.runoob.com/download/mysql-connector-java-5.1.39-bin.jar 也就是上图中最下面的那个Jar包
现在创建一个项目,并将上述lib文件夹拷贝到项目的根目录下,如果使用Eclipse就可以在项目上右键,点击最下方的属性,然后在弹窗的左边选择 Java Build Path
然后点击 Add JARs,选择lib中全部Jar包点击Apply完成Jar包的导入
1 基于 ClassName.hbm.xml 构建映射
一个类对应于一个 .hbm.xml文件,并且起名一定是类名加上.hbm.xml
还需要一个hibernate的配置文件 hibernate.cfg.xml
文件位置:
ClassName.hbm.xml要存放在与此类在同一个包下
hibernate.cfg.xml要存放在src路径下
下面是这个将参数写入数据库的详细过程:
首先我构造三个Table
table1:
table2:
table3:
解释:
table1只有一行,就是存储词表、词性表、以及共有多少个分词以及词性,由于模型的参数Pi是一个一维向量,我把它也存在了table1中,只是多分配一个字段而已
table2和table3的关键字段就是rowA和rowB,由于模型的参数A以及B是二维矩阵,所以这里设计是每一行存储矩阵对应的一行,在每一行中不同列的参数以空格分割并拼接为串
然后构建项目
由于有三个表,所以定义三个与之对应的实体类,当然要在同路径下创建三个配置文件:
对于Table1:
public class Table1 {
private int id;
private String wordList;
private String labelList;
private int wordSize;
private int labelSize;
private String pi; //Getter and Setter
}
同理,Table2和Table3就更好构建了
现在到了关键的配置文件,以Table1.hbm.xml为例
<!--在xlc包下-->
<hibernate-mapping package="hmmtrainmysql.xlc"> <!--类名为User,表名也为User-->
<class name="Table1" table="table1"> <!--主键映射,属性名为id,列名也为id-->
<id name="id" column="id">
<!--根据底层数据库主键自动增长-->
<generator class="native"/> </id> <!--非主键映射,属性和列名一一对应-->
<property name="wordList" type="text">
<!--length="16777216 表示使用LONGTEXT类型-->
<column name="wordList" length="16777216"/>
</property> <property name="labelList" type="text">
<column name="labelList" sql-type="text"/>
</property> <property name="wordSize" column="wordSize"/>
<property name="labelSize" column="labelSize"/> <property name="pi" type="text">
<column name="pi" length="16777216"/>
</property> </class>
</hibernate-mapping>
接下来就是hibernate.cfg.xml
<hibernate-configuration>
<!-- 通常,一个session-factory节点代表一个数据库 -->
<session-factory> <!-- 1. 数据库连接配置 -->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql:///parameter</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">123456</property>
<!-- 数据库方法配置, hibernate在运行的时候,会根据不同的方言生成符合当前数据库语法的sql -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property> <!-- 2. 其他相关配置 -->
<!-- 2.1 显示hibernate在运行时候执行的sql语句 由于代码中有频繁操作数据库我就把它注释掉了 -->
<!-- <property name="hibernate.show_sql">true</property> -->
<!-- 2.2 格式化sql -->
<property name="hibernate.format_sql">true</property>
<!-- 2.3 自动建表 -->
<property name="hibernate.hbm2ddl.auto">create</property> <!--3. 加载三个映射-->
<mapping resource="hmmtrainmysql/xlc/Table1.hbm.xml"/>
<mapping resource="hmmtrainmysql/xlc/Table2.hbm.xml"/>
<mapping resource="hmmtrainmysql/xlc/Table3.hbm.xml"/> </session-factory>
</hibernate-configuration>
最后是操作数据库的核心代码,这里给出如何将数据存储到数据库的
Configuration configuration = new Configuration(); //不给参数就默认加载hibernate.cfg.xml文件,
configuration.configure();
SessionFactory factory = configuration.buildSessionFactory();
Session session = factory.openSession();
Transaction transaction = session.getTransaction();
transaction.begin(); Table1 table1 = new Table1();
table1.setLabelSize(httm.labelSize);
table1.setWordSize(httm.wordSize);
table1.setLabelList(strLabel);
table1.setWordList(strWord);
table1.setPi(strPi); session.save(table1); for (int i = 0; i < httm.labelSize; i++) {
Table2 table2 = new Table2();
Table3 table3 = new Table3();
String strA = "";
String strB = "";
for (int j = 0; j < httm.labelSize; j++) {
strA += httm.A[i][j] + " ";
}
for (int k = 0; k < httm.wordSize; k++) {
strB += httm.B[i][k] + " ";
}
System.out.println(i);
table2.setRowA(strA);
session.save(table2);
table3.setRowB(strB);
session.save(table3);
} transaction.commit();
session.close();
运行程序结束后,成功写库
Github:https://github.com/xinglicha0/Offline-Train-Hmm-To-MySQL
2 基于Java注释 构建映射
后续完善
Java采用Hibernate连接MySQL的更多相关文章
-
Hibernate连接mysql数据库并自动创建表
天才第一步,雀氏纸尿裤,Hibernate第一步,连接数据库. Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个 ...
-
SpringBoot 整合 hibernate 连接 Mysql 数据库
前一篇搭建了一个简易的 SpringBoot Web 项目,最重要的一步连接数据库执行增删改查命令! 经过了一天的摸爬滚打,终于成功返回数据! 因为原来项目使用的 SpringMVC + Hibern ...
-
java中myeclipse连接mysql问题(java.lang.ClassNotFoundException: com.mysql.jdbc.Driver)
java中myeclipse连接mysql问题(java.lang.ClassNotFoundException: com.mysql.jdbc.Driver) 1.往项目中添加mysql-conne ...
-
JAVA使用jdbc连接MYSQL简单示例
以下展示的为JAVA使用jdbc连接MYSQL简单示例: import java.sql.DriverManager; import java.sql.ResultSet; import java.s ...
-
java用JDBC连接MySQL数据库的详细知识点
想实现java用JDBC连接MySQL数据库.需要有几个准备工作: 1.下载Connector/J的库文件,下载Connector/J的官网地址:http://www.mysql.com/downlo ...
-
Java Web工程连接MySQL数据库及Tomcat服务器页面中文乱码
Java Web工程连接MySQL数据库 一. 准备工作 1.下载连接MySQL数据库的JDBC (可以去官网下,也可以去百度云找) 2.将下载的jar文件复制到Tomcat的lib目录下 3.新建一 ...
-
Hibernate 连接MySQL/SQLServer/Oracle数据库的hibernate.cfg.xml文件
用Hibernate配置连接数据库可以方便我们对POJO的操作,节省了很多时间和代码.下面就分别说明连接不同数据库需要在hibernate.cfg.xml做的配置. 需要数据库驱动包可以点击这里下载: ...
-
ava基础MySQL存储过程 Java基础 JDBC连接MySQL数据库
1.MySQL存储过程 1.1.什么是存储过程 带有逻辑的sql语句:带有流程控制语句(if while)等等 的sql语句 1.2.存储过程的特点 1)执行效率非常快,存储过程是数据库的服 ...
-
Hibernate连接mysql数据库的配置
<?xml version='1.0' encoding='utf-8'?> <!DOCTYPE hibernate-configuration PUBLIC "-//Hi ...
随机推荐
-
map.c 添加注释
注释仅代表个人理解,难免有错误之处,仅供参考! 1 /* 2 * linux/drivers/base/map.c 3 * 4 * (C) Copyright Al Viro ...
-
位运算取第一个非0的位 r &; (~(r-1))
Single Number III Given an array of numbers nums, in which exactly two elements appear only once and ...
-
struts2框架开发的第一个应用
写这篇博文,主要是帮助那些刚接触struts2框架开发而不知所措的人,希望批评指正 一.先建立一个web project,命名为struts2 二.在webroot/WEB-INF/lib目录下添加如 ...
-
Linux创建公钥
A:192.168.1.1 B:192.168.1.2 现在想让A无密码登陆B机器 A上运行以下命令来生成公钥和私钥 ssh-keygen -t rsa -P '' 运行该命令后会生成如下两个文件 ...
-
去除ActionBar的方法
今天做一个播放器项目,由于要去除ActionBar,纠结好久,原来这么简单 记录一下 只需要修改AndroidManifest.xml文件中的主题即可 <application android: ...
-
qt 程序启动参数 -qws
运行嵌入式程序 在嵌入式QT版本中,程序需要服务器或自己作为服务器程序.服务器程序构造的方法是构造一个QApplication::GuiServe类型的QApplication对象.或者使用-qws命 ...
-
svn简介与使用
本文简单介绍windows下svn服务器与客户端软件的简单应用. 其中,svn服务器用于储存和管理代码,相当与文本服务器的作用(多版本控制等功能),同时分配用户代码的访问与使用权限. 客户端软件 用于 ...
-
rancher2 接NFS存储
一.NFS服务器搭建 略 二.rancher 2配置--PV配置 集群名称---Storage --增加 Persistent Volume 名称任意,卷插件选nfs Share 容量按需求 插件配置 ...
-
redis学习(三)redis持久化
redis持久化 1.redis持久化介绍 我们知道redis性能之所以强悍,是因为redis在运行时将数据都存放在了访问效率远高于硬盘的内存之中.可是这带来了新的问题:在redis或者外部系统重启时 ...
-
XnView查看图片实际大小
找了很多软件,只有它可以显示尺寸大小. 各位如有别的发现,可留言推荐,谢谢