HSQL基本使用(linux),安装+Demo

下载

http://sourceforge.net/projects/hsqldb/files/

安装

将下载的包,解压到任意目录即可

运行

通过java命令启动

java -classpath /root/hsql/hsqldb-2.4.1/hsqldb/lib/hsqldb.jar org.hsqldb.Server -database.0 file:/home/hsqldbfile/jxima/hqdb -dbname.0 hqdb

-classpath表示启动需要依赖的jar包,指定到hsql安装目录下的对应地址
org.hsqldb.Server 表示server模式启动
-database.0 表示第一个数据库
file 表示数据库文件存储路径
-dbname.0 表示第一个数据库名称

[root@supervisordruid1 hsqldb-2.4.1]# java -classpath /root/hsql/hsqldb-2.4.1/hsqldb/lib/hsqldb.jar org.hsqldb.Server -database.0 file:/home/hsqldbfile/jxima/hqdb -dbname.0 hqdb
[Server@1fb3ebeb]: Startup sequence initiated from main() method
[Server@1fb3ebeb]: Could not load properties from file
[Server@1fb3ebeb]: Using cli/default properties only
[Server@1fb3ebeb]: Initiating startup sequence...
[Server@1fb3ebeb]: Server socket opened successfully in 11 ms.
[Server@1fb3ebeb]: Database [index=0, id=0, db=file:/home/hsqldbfile/jxima/hqdb, alias=hqdb] opened successfully in 841 ms.
[Server@1fb3ebeb]: Startup sequence completed in 856 ms.
[Server@1fb3ebeb]: 2019-04-08 06:37:26.042 HSQLDB server 2.4.1 is online on port 9001
[Server@1fb3ebeb]: To close normally, connect and execute SHUTDOWN SQL
[Server@1fb3ebeb]: From command line, use [Ctrl]+[C] to abort abruptly

使用数据库

项目中数据库配置文件配置

jdbc.url=jdbc:hsqldb:hsql://10.223.138.236(服务器IP)/hqdb (hqdb为数据库启动时配置的-dbname)
jdbc.username=sa
jdbc.password=

demo

import java.sql.*;

public class HsqlDemo {
	public static void main(String[] args) {
		Statement stmt = null;
		ResultSet rs = null;
		Connection connection = null;

		try {
			Class.forName("org.hsqldb.jdbcDriver");
//    		String URL="jdbc:hsqldb:hsql://10.0.1.21:5432/school";
			String URL="jdbc:hsqldb:hsql://localhost";
			//
			String USER="SA";
			String PASSWORD="";
//			connection = DriverManager.getConnection("jdbc:hsqldb:hsql://10.0.1.224:9001/", "SA", "");
			connection = DriverManager.getConnection("jdbc:hsqldb:hsql://10.0.3.42:9001/hqdb", "SA", "");

//            Connection c = DriverManager.getConnection(URL, USER, PASSWORD);
			if (connection != null) {
				System.out.println("Connected db success!");
//                String sql = "CREATE TABLE TBL_USERSSYXFA(ID INTEGER, NAME VARCHAR, BIRTHDAY DATE);";
				//增删改查
//                String sql = "CREATE TABLE TBL_USERSAARONAY(ID INTEGER, NAME INTEGER, BIRTHDAY DATE);";
//                sql = "INSERT INTO TBL_USERSAARONAY(ID, NAME, BIRTHDAY) VALUES ('2', '2', SYSDATE);";

				String sql1 = "CREATE TABLE TEST(NAME INTEGER,SEX INTEGER)";
				String sql2 = "INSERT INTO TEST VALUES('1','2')";
				String sql5 = "INSERT INTO TEST VALUES('3','4')";
				String sql3 = "select * from TEST";
				String sql4 = "DROP TABLE IF EXISTS TEST";
				stmt = connection.createStatement();
				stmt.execute(sql4);
				stmt.execute(sql1);
				stmt.execute(sql2);
				PreparedStatement prepareStatement1 = connection.prepareStatement(sql5);
				prepareStatement1.execute();
				PreparedStatement prepareStatement2 = connection.prepareStatement(sql3);
				rs  = prepareStatement2.executeQuery();
				while(rs.next()) {
					System.out.println(rs.getString("NAME")+"的性别是"+rs.getString("SEX"));
				}
//                stmt.executeUpdate(sql);
				if (stmt != null) {
					stmt.close();
				}
				connection.close();
			}
		} catch(Exception e) {
			System.out.println("ERROR:failed to load HSQLDB JDBC driver.");
			e.printStackTrace();
			return;
		}
	}
}

pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.leesin</groupId>
    <artifactId>hsql_demo</artifactId>
    <version>1.0-SNAPSHOT</version>
    <name>hsql</name>
    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>

    <dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>3.8.1</version>
            <scope>test</scope>
        </dependency>

        <dependency>
        <groupId>org.hsqldb</groupId>
        <artifactId>hsqldb-j5</artifactId>
        <version>2.2.4</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.hsqldb/hsqldb -->
        <!-- https://mvnrepository.com/artifact/org.testifyproject.local-resources/hsql -->
        <!--<dependency>-->
            <!--<groupId>org.testifyproject.local-resources</groupId>-->
            <!--<artifactId>hsql</artifactId>-->
            <!--<version>1.0.2</version>-->
        <!--</dependency>-->

    </dependencies>
    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-jar-plugin</artifactId>
                <configuration>
                    <classesDirectory>${project.build.directory}/classes</classesDirectory>
                    <archive>

                        <manifest>

                            <addClasspath>true</addClasspath>

                            <classpathPrefix>lib/</classpathPrefix>

                            <mainClass>com.hlsq.HsqlDemo</mainClass>

                            <useUniqueVersions>false</useUniqueVersions>

                        </manifest>

                        <manifestEntries>

                            <Class-Path>${basedir}/src/lib/hsqldb.jar</Class-Path>

                        </manifestEntries>

                    </archive>

                </configuration>

            </plugin>


        </plugins>
    </build>

</project>

注意

server端(安装的hsql)和client端(java代码的 maven jar包)的版本可能会有不兼容

我这里server端用的2.2.4 client端用的 2.2.4

转载于:https://www.cnblogs.com/LeesinDong/p/10835285.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在JPA中,HQL(Hibernate Query Language)是一种面向对象的查询语言,用于查询数据库中的实体对象。HQL与SQL语法类似,但是使用实体类和属性名代替表名和列名。在JPA中,可以使用@Query注解来编写HQL查询。 例如,在使用JPA的@Repository注解标注的接口中,可以使用@Query注解来编写HQL查询语句。在@Query注解中,可以使用实体类和属性名来代替表名和列名。同时,可以使用参数占位符(如:name)来传递参数。 下面是一个使用HQL查询的示例代码: ```java @Repository public interface UserRepository extends JpaRepository<User, Long> { @Query("SELECT u FROM User u WHERE u.email = :email") User findByEmail(@Param("email") String email); } ``` 在上述示例中,使用@Query注解编写了一个HQL查询语句,查询email属性等于传入参数email的User对象。 需要注意的是,HQL查询语句中的实体类和属性名是区分大小写的,且与数据库表和列名无关。因此,在编写HQL查询时,需要确保实体类和属性名的正确性。 希望以上信息对您有所帮助。\[1\]\[3\] #### 引用[.reference_title] - *1* [Spring Data JPA的使用。](https://blog.csdn.net/liuno0/article/details/124979302)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [JPA中使用delete踩坑记录](https://blog.csdn.net/qq_43680542/article/details/109724364)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Spring访问数据库使用JPA](https://blog.csdn.net/zy199701/article/details/113833903)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值