[saiku] 将saiku自带的H2嵌入式数据库迁移到本地mysql数据库

saiku数据库的表和用户默认创建是在启动项目的时候,通过初始化 saiku-beans.xml 中的 h2database 这个 bean 

执行org.saiku.service.Database类的init方法来初始化数据表和默认用户的。

 

具体修改如下:

1/修改web.xml 中 数据连接配置信息

将数据库链接修改为本地mysql配置信息:

  <context-param>
    <param-name>db.url</param-name>
    <param-value>jdbc:mysql://localhost:3306/saiku</param-value>
  </context-param>
  <context-param>
    <param-name>db.user</param-name>
    <param-value>root</param-value>
  </context-param>
  <context-param>
    <param-name>db.password</param-name>
    <param-value>root</param-value>
  </context-param>

 

2/修改saiku-beans.xml中h2database配置信息

新增mysql数据源适配:

 

    <bean id="h2database" class="org.saiku.database.Database" init-method="init">
        <property name="datasourceManager" ref="repositoryDsManager"/>
        <property name="datasourcetype" value="mysql" />
    </bean>

 

3/修改Database中获取的数据源为mysql

修改Database类:

private String datasourcetype = "mysql";

private void initDB() {

        String url = servletContext.getInitParameter("db.url");
        String user = servletContext.getInitParameter("db.user");
        String pword = servletContext.getInitParameter("db.password");

        if (this.datasourcetype.equals("mysql")) {
            ds = new MysqlDataSource();
            ((MysqlDataSource) ds).setUrl(url);
            ((MysqlDataSource) ds).setUser(user);
            ((MysqlDataSource) ds).setPassword(pword);
        } else if (this.datasourcetype.equals("h2")) {
            ds = new JdbcDataSource();
            ((JdbcDataSource) ds).setUrl(url);
            ((JdbcDataSource) ds).setUser(user);
            ((JdbcDataSource) ds).setPassword(pword);
        }

    }

 

4/因为h2建表sql和mysql的还是有差异的,所以将创建表和用户信息的代码替换如下:

mysql数据表和用户的创建代码为:

 

    private void loadUsers() throws SQLException {

        Connection c = ds.getConnection();

        Statement statement = c.createStatement();

        statement.execute(" CREATE TABLE IF NOT EXISTS log ( time  TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP, log  TEXT); ");
        statement.execute(" CREATE TABLE IF NOT EXISTS users(user_id INT(11) NOT NULL AUTO_INCREMENT, " + " username VARCHAR(45) NOT NULL UNIQUE, password VARCHAR(100) NOT NULL, email VARCHAR(100), " + " enabled TINYINT NOT NULL DEFAULT 1, PRIMARY KEY(user_id)); ");
        statement.execute(" CREATE TABLE IF NOT EXISTS user_roles ( " + " user_role_id INT(11) NOT NULL AUTO_INCREMENT,username VARCHAR(45), "  + " user_id INT(11) NOT NULL REFERENCES users(user_id), " + " ROLE VARCHAR(45) NOT NULL, " + " PRIMARY KEY (user_role_id)); ");

        ResultSet result = statement.executeQuery("select count(*) as c from log where log = 'insert users'");

        result.next();

        if (result.getInt("c") == 0) {

            statement.execute("INSERT INTO users (username,password,email, enabled) VALUES ('admin','admin', 'test@admin.com',TRUE);");
            statement.execute("INSERT INTO users (username,password,enabled) VALUES ('smith','smith', TRUE);");
            statement.execute("INSERT INTO user_roles (user_id, username, ROLE) VALUES (1, 'admin', 'ROLE_USER');");
            statement.execute("INSERT INTO user_roles (user_id, username, ROLE) VALUES (1, 'admin', 'ROLE_ADMIN');");
            statement.execute("INSERT INTO user_roles (user_id, username, ROLE) VALUES (2, 'smith', 'ROLE_USER');");
            statement.execute("INSERT INTO log (log) VALUES('insert users');");
        }

        String encrypt = servletContext.getInitParameter("db.encryptpassword");
        if (encrypt.equals("true") && !checkUpdatedEncyption()) {
            updateForEncyption();
        }
    }

    public boolean checkUpdatedEncyption() throws SQLException{
        Connection c = ds.getConnection();
        Statement statement = c.createStatement();
        ResultSet result = statement.executeQuery("select count(*) as c from log where log = 'update passwords'");
        result.next();
        return result.getInt("c") != 0;
    }

    public void updateForEncyption() throws SQLException {

        Connection c = ds.getConnection();
        Statement statement = c.createStatement();
        statement.execute("ALTER TABLE users MODIFY COLUMN PASSWORD VARCHAR(100) DEFAULT NULL");
        ResultSet result = statement.executeQuery("select username, password from users");
        while (result.next()) {
            statement = c.createStatement();
            String pword = result.getString("password");
            String hashedPassword = passwordEncoder.encode(pword);
            String sql = "UPDATE users " + "SET password = '" + hashedPassword
                    + "' WHERE username = '" + result.getString("username")
                    + "'";
            statement.executeUpdate(sql);
        }
        statement = c.createStatement();
        statement.execute("INSERT INTO log (log) VALUES('update passwords');");
    }

以上的信息修改完毕后,在本地mysql创建url中指定的database->saikuBase,此时db中无任何表

运行saiku项目成功后,刷新db,可以看见db中多出了三张表user/user_roles/log,说明初始化表和默认数据已经成功。

但是,此时只是创建了表结构和默认的登陆账户,并没有修改登录的用户认证数据源。

当我们使用admin登陆时还是会访问到jdbc中配置的h2数据库数据源。

其实这时候还是通过访问h2内嵌数据库的db文件登陆的,在管理端新建的用户也会保存在h2数据源中,mysql数据源中查询不到新建的用户

所以,接下来要修改认证数据源为本地的mysql

 

5/修改用户认证数据源

将 bean id 为 datasource 的 数据源的配置信息改为我们本地mysql的配置信息,重新部署服务并启动

这时,我们在管理端创建一个用户saiku,点击保存。

查看本地mysql数据库的user表,能看见saiku已经存在user表中了,并且使用saiku用户登录也能登录成功。

将*security-jdbc.xml 中的配置信息改成mysql的即可

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" >
        <property name="driverClassName" value="mysql的驱动"/>
        <property name="url" value="mysql的url"/>
        <property name="username" value="账户名"/>
        <property name="password" value="密码"/>
</bean>

至此就完成了h2数据库迁移到本地mysql的操作了

原文地址:http://www.cnblogs.com/avivaye/p/4881106.html#3442020

时间: 2024-10-26 08:50:37

[saiku] 将saiku自带的H2嵌入式数据库迁移到本地mysql数据库的相关文章

Wince MFC OLE DB SQLCE数据库访问技术(二):嵌入式目标平台创建本地数据库sdf文件

前言 上一节已经讲述了嵌入式目标平台上安装sqlCE,本章将介绍如何在目标平台上创建本地数据库sdf文件. 备注:博客中所有关于Wince MFC OLE DB   SQLCE数据库访问技术的文章都是基于SQL Server 2005 Compact Edition即 sqlCE 3.x     在讲述sqlCE之前,先来了解下,sqlCE优于wince 自带数据库的特点: 类别 对象 最大大小限制 存储 列名 128 个字符   表中的列数 1024 行大小 8060 字节   数据库密码 4

带一般处理程序的web网站在本地部署可以,在服务器上部署不起作用

问题描述 带一般处理程序的web网站在本地部署可以,在服务器上部署不起作用 带一般处理程序的web网站在本地部署可以,在服务器上部署不起作用

windows10 自带的hyper虚拟机 无法连接到本地的计算机

问题描述 windows10 自带的hyper虚拟机 无法连接到本地的计算机 bios也开启了虚拟化啊... 解决方案 根据提示,打开任务管理器-服务,找到他的服务看看有没有运行,是不是被一些"优化软件"删除或禁用了.或者你可以用vmware,这个更好用 解决方案二: 升级windows 10 后vmware中的虚拟机无法打开

通过notes系统自带的修复工具修复损坏的notes个人数据库

今天咱们就介绍一下,如何通过notes系统自带的修复工具修复损坏的个人数据库,那是什么工具呢,那就是fixup.exe,这个程序是notes系统自带的修复工具,类似于office自带的patscan工具,pstscan用来修复.pst数据文件的,废话不多说了,操作具体见下. 环境介绍:环境内部署了一台版本为domino 8.5.1的domino服务器,然后安装路径及数据库路径均安装到D盘下,我们也知道,notes个人数据库存放路径在数据库路径下的mail文件夹下,我们今天就比如lisi这个用户的

使用带dblink方式的datapump迁移Oracle 10g到11g

      对于从Oracle 10g下迁移数据库到Oracle 11g,除了使用RMAN方式之外,我们可以使用带dblink的datapump方式来实现基于逻辑上的迁移.其步骤也相对简单,而且不会产生中间过程生成的dump文件.本文即针对如何使用该方法给出了示例,供大家参考.   1.确保源数据库和目标数据库处于可用状态 --环境描述 --源库: mftst Oracle 10.2.0.3 + Enterprise Linux Enterprise Linux Server release 5

当用EXP(带direct=y参数)导出一个带坏块的数据库时,不会报警!!!

http://www.itpub.net/470649.html Exp导出可以检测physical corruption 和logical corruption 但是有一些限制: 原文如下: 1. Export only reads: - user data below the high water mark; - parts of the data dictionary, while looking up information concerning the objects being ex

C++用mysql自带的头文件连接数据库_C 语言

mysql.h文件在哪,怎么查找.自行百度 #include <mysql/mysql.h> #include <stdio.h> #include<iostream> #include<fstream> #include<string.h> using namespace std; MYSQL *conn; MYSQL_RES *res; MYSQL_ROW row; class people { public: char name[20];

springboot和mybatis结合

springboot和mybatis结合 依赖和数据源配置 springboot依赖了spring4,需要依赖mybatis-spring,最新版本是1.2.2. 数据源相关的依赖: <!-- datasource --> <dependency> <groupId>com.zaxxer</groupId> <artifactId>HikariCP-java6</artifactId> <version>${HikariC

springboot和mybatis两个框架结合教程

本文我们来讲讲springboot和mybatis如何结合 依赖和数据源配置 springboot依赖了spring4,需要依赖mybatis-spring,最新版本是1.2.2. 数据源相关的依赖: <!-- datasource --> <dependency>     <groupId>com.zaxxer</groupId>     <artifactId>HikariCP-java6</artifactId>     <