Java采用Hibernate连接MySQL
现有环境:
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 ...
随机推荐
- JavaScript之获取表格目标数据(TableDom.getTableData())
[声明: 1.博文原创 未经同意转载必究,欢迎相互交流] [声明: 2.博主未知情况下转载,需显著处注明博文来源] [声明: 3.谢谢尊重劳动成果,谢谢理解与配合~] 一.背景 在生产过程和生活 ...
- CF1009F Dominant Indices
传送门 还是放个链接让泥萌去学一下把 orzYYB 题目中要求的\(f_{x,j}\),转移是\(f_{x,j}=\sum_{y=son_x} f_{y,j-1}\),所以这个东西可以用长链剖分优化, ...
- SpringBoot使用外置的Servlet容器
SpringBoot默认使用嵌入式的Servlet容器,应用打包成可执行的jar包 优点:简单.便携 缺点:默认不支持jsp,优化定制比较复杂(使用定制器serverProperties.自定义Emb ...
- python内置模块之unittest测试(五)
系列文章 python模块分析之random(一) python模块分析之hashlib加密(二) python模块分析之typing(三) python模块分析之logging日志(四) pytho ...
- ubuntu 用 apt get 安装某个包的某个版本
1.首先用如下命令查询你的机器安装了哪些版本: dpkg -l 'apache2*' 2.然后用如下命令查询远程库存在哪些版本: apt-cache madison "libqt5gui5& ...
- oracle数据文件迁移
这篇文章是从网络上获取的,然后根据内容一步步操作, 1.目前的疑问:移动日志文件的时候,为何要先进行切换? 2.move操作后,再进行rename操作的原理 --------------------- ...
- CentOS 6.5下的lamp环境rsyslog+MySQL+loganalyzer实现日志集中分析管理
前言 rsyslog系统日志,在CentOS5上叫syslog,而在CentOS6上叫rsyslog,是增强版的syslog,CentOS5上的配置文件在/etc/syslog.conf下,而Cent ...
- Ubuntu下安装Golang并测试HelloWorld
Intel Core i5-8250U,Ubuntu 18.04(安装在虚拟机Oracle VirtualBox 5.2.12上),Go 1.11, 安装步骤如下: -进入Go文档官网: https: ...
- Day6------------硬盘分区
1.sda1 sd:串行接口 a:第一块硬盘 1:第一个分区 ls /dev/sd 查看硬盘 fdisk -l /dev/sda 查看分区信息 block------------>8*512 8 ...
- javascript NaN注意事项
NaN直译是Not a number NaN是个特殊的number,它和任何值相比都不相等,甚至和它自己. NaN === NaN 这个表达式是false 唯一能判断NaN的方法是 IsNaN(NaN ...