java游戏数据储存,Java游戏服务器之数据库表存取封装

项目涉及的数据库表并不多,但每个select、insert、update和delete都去手动拼接字符串,是很低效的,尤其在时常要修改结构的情况下。开发的一个目标就是自动化,即能自动实现的事情就不要手动去做;还有一个原则是单一化,即尽量保证数据或逻辑一个入口一个出口。这个需求可以使用一些开源库解决,但因为需求简单,目标明确,没有必要引入多余的第三方库。于是自己写了一个,至少满足当前需求。

数据库表的封装,核心类有两个,表(Table)和记录(Record)。首先需要一个Table类保存数据库表结构的描述,并籍此自动生成相应SQL语句。其次需要一个Record类自动设置SQL参数,并从返回结果集中自动生成逻辑对象。

table类表结构描述可以有两个来源,自动从数据库获取,或从配置表加载。这里选择从配置表加载的方式,一来实现简单,二来应用面更广。

下面是一个账户表的配置示例(user.xml)。

?

只定义了一个主键,有需要可对此扩充。每列name对应数据库表的列名,field对应逻辑对象的成员变量名,type对应字段的类型,比如是int、string、timestamp等,有了名字和类型,就可以使用反射方式自动get和set数据。

Table类读取配置文件获得数据表的结构描述。

?

然后生成PrepareStatement方式读写的select、insert、update和delete的预处理SQL字符串。如update:

?

Table类的功能就这么多,下面是关键的Record类,其使用反射自动存取数据。

?

模板参数T即一个表记录对应的逻辑对象。在我们的示例里,即账户数据类:

?

有了SQL语句,要先设置参数,才能执行。主键和普通字段分开设置。

?

就是根据表结构描述,通过反射获取对应字段的值然后设置。

?

toDBValue作用是将Java逻辑类型转成对应数据库类型,比如时间,在逻辑里是Long,而数据库类型是Timestamp。

?

以设置update SQL参数为例:

?

之后执行该SQL语句就可以了。如果是select语句还会返回结果集(ResultSet),从结果集自动生成逻辑对象原理类似,算是一个逆过程,详细参看文末代码。

下面给出一个使用的完整示例:

?

代码封装得很简易,有更多需求可据此改进。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中使用Redis存取数据,你需要使用Redis的Java客户端来与Redis服务器进行交互。以下是一个简单的示例代码: 1. 首先,你需要添加Redis的Java客户端依赖。常用的Java Redis客户端有Jedis和Lettuce,你可以选择其中一个。 对于Jedis,可以在项目的pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>3.7.0</version> </dependency> ``` 对于Lettuce,可以在项目的pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>io.lettuce</groupId> <artifactId>lettuce-core</artifactId> <version>6.2.5.RELEASE</version> </dependency> ``` 2. 创建Redis连接并进行数据存取操作。 使用Jedis客户端的示例代码如下: ```java import redis.clients.jedis.Jedis; public class RedisExample { public static void main(String[] args) { // 创建Redis连接 Jedis jedis = new Jedis("localhost", 6379); // 存储数据 jedis.set("key", "value"); // 获取数据 String value = jedis.get("key"); System.out.println(value); // 关闭连接 jedis.close(); } } ``` 使用Lettuce客户端的示例代码如下: ```java import io.lettuce.core.RedisClient; import io.lettuce.core.RedisURI; import io.lettuce.core.api.StatefulRedisConnection; import io.lettuce.core.api.sync.RedisCommands; public class RedisExample { public static void main(String[] args) { // 创建Redis连接 RedisURI uri = RedisURI.Builder.redis("localhost", 6379).build(); RedisClient client = RedisClient.create(uri); StatefulRedisConnection<String, String> connection = client.connect(); RedisCommands<String, String> commands = connection.sync(); // 存储数据 commands.set("key", "value"); // 获取数据 String value = commands.get("key"); System.out.println(value); // 关闭连接 connection.close(); client.shutdown(); } } ``` 这是一个简单的示例,你可以根据自己的需求进行更复杂的数据存取操作。记得在使用完毕后关闭连接以释放资源。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值