PropertySet教程-3.JDBC方式

本文档介绍了如何使用PropertySet的JDBC方式进行键值对的持久化,涉及IBM DB2数据库的表创建、配置文件设置、所需Jar包以及演示代码。通过示例展示了在非Web容器环境下,如何初始化JNDI并进行数据存储和读取。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  inkfish原创,请勿商业性质转载,转载请注明来源(http://blog.youkuaiyun.com/inkfish )。

  PropertySet(来源:http://blog.youkuaiyun.com/inkfish) 是由opensymphony组织开发的的一个开源项目,但是那个项目文档少,长时间没有更新,官方文档错误奇多,所以现在在项目中使用并不广泛。但这并 不妨碍PropertySet成为一个优秀的key-value持久化模块,当前,PropertySet可以说已经够用。这里我整理书写了 PropertySet的文档。(来源:http://blog.youkuaiyun.com/inkfish)


  介绍完了memory、map、XML方式,该JDBC方式登场了。JDBC方式存储,一定需要一个关系数据库,这里我用的是IBM DB2 v9.7。(来源:http://blog.youkuaiyun.com/inkfish)

1.建表SQL (来源:http://blog.youkuaiyun.com/inkfish)

  下载下来的PropertySet包里不包含建表SQL,需要自己照葫芦画瓢来写,当然也有方便的方法,就是去下一个osworkflow,在src/etc/deployment/jdbc 目录下有一堆数据库的建表SQL,其中就包含了PropertySet的建表SQL。(来源:http://blog.youkuaiyun.com/inkfish)

2.配置文件 (来源:http://blog.youkuaiyun.com/inkfish)

  propertyset.xml 放在classpath根路径下,内容:(来源:http://blog.youkuaiyun.com/inkfish)

  注:这个配置文件和propertyset默认的配置文件不同处在于仅有JDBC一段的配置,并且修改了JNDI名称。由于示例中不使用web容器,仅仅偷用tomcat的jar包里简单的JNDI naming服务,所以JNDI名字取的是一个不带“/”的字符串,如果带“/”如“jdbc/db2ds”会报错。(来源:http://blog.youkuaiyun.com/inkfish)

 

3.Jar包依赖 (来源:http://blog.youkuaiyun.com/inkfish)

需要的jar包除上一篇中的那些jar包,还需要:(来源:http://blog.youkuaiyun.com/inkfish)

  1.数据库JDBC驱动:db2jcc.jar、db2jcc_license_cu.jar
  2.tomcat里的jar:catalina.jartomcat-juli.jar
  3.EJB的jar:ejb-api.jar ,带EJB的jar是因为com.opensymphony.module.propertyset.JDBCPropertySet 中使用了com.opensymphony.util.EJBUtilsEJBUtils 中某些需要被调用的方法使用了EJB的API。(来源:http://blog.youkuaiyun.com/inkfish)

 

4.Demo代码 (来源:http://blog.youkuaiyun.com/inkfish)

 

5.典型实践(来源:http://blog.youkuaiyun.com/inkfish)

  在一个项目中,每个人分成不同的模块,在测试机或者自己的本机各搭建了多个环境,每个环境有不同的参数,大家把配置信息存放到XML中,随时可以打开修改。在最后集成测试时,把配置信息统一放到测试机的测试数据库中进行统一管理。不同模块使用不同globalKey以防冲突。(来源:http://blog.youkuaiyun.com/inkfish)

我的代码package hotel; import java.sql.Connection; import java.sql.DriverManager; import java.sql.Statement; /**jdbc快速入门demo*/ public class JDBCDemo2 { public static void main(String[] args) throws Exception { // Class.forName("com.mysql.jdbc.Driver"); //注册驱动 String url ="jdbc:mysql://127.0.0.1:3306/hotel?useSSL=false"; String username = "root"; String password = "Lqh2005320"; //获取链接 Connection conn = DriverManager.getConnection(url,username,password); //执行sql语句 String sql= "update room set stock = 15where id = 1"; Statement stmt = conn.createStatement();//获取对象statement int count = stmt.executeUpdate(sql); } } 出现错误D:\程序\bin\java.exe "-javaagent:C:\Users\moon\IntelliJ IDEA 2024.1.1\lib\idea_rt.jar=3640:C:\Users\moon\IntelliJ IDEA 2024.1.1\bin" -Dfile.encoding=UTF-8 -Dsun.stdout.encoding=UTF-8 -Dsun.stderr.encoding=UTF-8 -classpath D:\tem\jdbc\out\production\jdbc-demo;D:\tem\jdbc\jdbc-demo\lib\mysql-connector-java-8.0.11.jar hotel.JDBCDemo2 Exception in thread "main" java.sql.SQLException: The server time zone value &#39;Öйú±ê׼ʱ¼ä&#39; is unrecognized or represents more than one time zone. You must configure either the server or JDBC driver (via the serverTimezone configuration property) to use a more specifc time zone value if you want to utilize time zone support. at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:127) at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:95) at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:87) at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:61) at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:71) at com.mysql.cj.jdbc.exceptions.SQLExceptionsMapping.translateException(SQLExceptionsMapping.java:76) at com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:862) at com.mysql.cj.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:444) at com.mysql.cj.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:230) at com.mysql.cj.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:226) at java.sql/java.sql.DriverManager.getConnection(DriverManager.java:683) at java.sql/java.sql.DriverManager.getConnection(DriverManager.java:230) at hotel.JDBCDemo2.main(JDBCDemo2.java:15) Caused by: com.mysql.cj.exceptions.InvalidConnectionAttributeException: The server time zone value &#39;Öйú±ê׼ʱ¼ä&#39; is unrecognized or represents more than one time zone. You must configure either the server or JDBC driver (via the serverTimezone configuration property) to use a more specifc time zone value if you want to utilize time zone support. at java.base/jdk.internal.reflect.DirectConstructorHandleAccessor.newInstance(DirectConstructorHandleAccessor.java:62) at java.base/java.lang.reflect.Constructor.newInstanceWithCaller(Constructor.java:502) at java.base/java.lang.reflect.Constructor.newInstance(Constructor.java:486) at com.mysql.cj.exceptions.ExceptionFactory.createException(ExceptionFactory.java:59) at com.mysql.cj.exceptions.ExceptionFactory.createException(ExceptionFactory.java:83) at com.mysql.cj.util.TimeUtil.getCanonicalTimezone(TimeUtil.java:128) at com.mysql.cj.protocol.a.NativeProtocol.configureTimezone(NativeProtocol.java:2201) at com.mysql.cj.protocol.a.NativeProtocol.initServerSession(NativeProtocol.java:2225) at com.mysql.cj.jdbc.ConnectionImpl.initializePropsFromServer(ConnectionImpl.java:1391) at com.mysql.cj.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:993) at com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:852) ... 6 more 进程已结束,退出代码为 1
最新发布
03-29
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值