Apache sdo学习笔记(六)——数据访问服务(DAS)访问关系数据库

1:建立数据库(dastest)和表(userinfo),这里使用mysql,如下图:

2:配置文件UsersConfig.xml,src下。

<?xml version="1.0" encoding="UTF-8"?>
 <Config xmlns="http:///org.apache.tuscany.das.rdb/config.xsd"> 
    
	<ConnectionInfo>
		<ConnectionProperties driverClass="com.mysql.jdbc.Driver"
			databaseURL="jdbc:mysql://127.0.0.1/dastest" userName="root" password="123"
			loginTimeout="600000" />
	</ConnectionInfo>
		
    <Command name="users" SQL="select * from userinfo" kind="Select" />
	
</Config>


3:java代码

 

package com.waysoft.intergration.dao;

import java.io.InputStream;
import java.text.DateFormat;
import java.util.Calendar;
import java.util.List;

import org.apache.tuscany.das.rdb.Command;
import org.apache.tuscany.das.rdb.DAS;

import commonj.sdo.DataObject;

public class CustomerClient {

	private DAS das = null;
	private final String configFile;

	public CustomerClient(String configFile) {
		this.configFile = configFile;
	}

	protected InputStream getConfig(String fileName) {
		return getClass().getClassLoader().getResourceAsStream(fileName);
	}

	protected DAS getDAS() {
		if (this.das == null) {
			this.das = DAS.FACTORY.createDAS(getConfig(this.configFile));
		}
		return this.das;
	}

	public final DataObject getRootObject() {
		Command read = this.getDAS().createCommand("select * from userinfo");
		DataObject root = read.executeQuery();
		return root;
	}

	public final List<?> getusers() {
		Command read = this.getDAS().createCommand("select * from userinfo");
		DataObject root = read.executeQuery();
		return root.getList("userinfo");
	}

	public final void addCustomer() {
		Command read = this.getDAS().getCommand("users");
		DataObject root = read.executeQuery();

		DataObject newUser = root.createDataObject("userinfo");
		newUser.setString("name", "chu");
		newUser.setInt("id", 3);
		newUser.setInt("age", 34);
		newUser.setString(
				"birth",
				DateFormat.getDateInstance().format(
						Calendar.getInstance().getTime()));
		das.applyChanges(root);
	}

	public final void deleteCustomer() {
		Command readAll = this.getDAS().getCommand("users");
		DataObject root = readAll.executeQuery();
		List<?> allusers = root.getList("userinfo");
		DataObject lastCustomer = (DataObject) allusers
				.get(allusers.size() - 1);
		if (lastCustomer != null) {
			System.out.println("Deleting user named: "
					+ lastCustomer.getString("name"));
			lastCustomer.delete();
		}
		das.applyChanges(root);
	}

	public final void changeFirstCustomerName() {
		Command readAll = this.getDAS().getCommand("users");
		DataObject root = readAll.executeQuery();

		DataObject firstCustomer = root.getDataObject("userinfo[1]");
		firstCustomer.set("name", "BlueBerry");

		das.applyChanges(root);
	}

	public static void printList(List<?> users) {
		for (int i = 0; i < users.size(); i++) {
			System.out.println(" name:"
					+ (((DataObject) users.get(i)).getString("name")) + " age:"
					+ (((DataObject) users.get(i)).getInt("id")) + " birth:"
					+ (((DataObject) users.get(i)).getString("birth")));
		}
	}

	public void releaseResources() {
		das.releaseResources();
	}

	public static void main(String[] args) {
		String customerConfigFile = "UsersConfig.xml";
		CustomerClient customerClient = new CustomerClient(customerConfigFile);
		// test select
		System.out.println();
		System.out.println("Result:select all users");
		printList(customerClient.getusers());
		// //test insert
		System.out.println();
		 System.out.println("Result:insert new userinfo");
		 customerClient.addCustomer();
		 printList(customerClient.getusers());

		// test update
		System.out.println();
		System.out.println("Result:update first userinfo");
		customerClient.changeFirstCustomerName();
		printList(customerClient.getusers());

		// test delete
		System.out.println();
		System.out.println("Result:delete last userinfo");
		customerClient.deleteCustomer();
		printList(customerClient.getusers());
	}
}


4:控制台输出

Result:select all users
 name:chu age:1 birth:2012-01-01

Result:insert new userinfo
 name:chu age:1 birth:2012-01-01
 name:chu age:3 birth:2012-12-13

Result:update first userinfo
 name:BlueBerry age:1 birth:2012-01-01
 name:chu age:3 birth:2012-12-13

Result:delete last userinfo
Deleting user named: chu
 name:BlueBerry age:1 birth:2012-01-01


5:查看数据库

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Apache Mina是一个用于开发高性能、高可扩展性网络应用程序的Java框架。它提供了一种简单和灵活的方式来构建基于TCP/IP和UDP/IP协议的客户端和服务器端应用。 在学习Apache Mina时,首先需要了解它的基本概念和架构。Mina采用了NIO(非阻塞IO)的方式来实现网络通信。它的核心组件是IoService,它负责接收客户端的连接请求,并将请求分发给对应的I/O处理器进行处理。而I/O处理器则负责实际的数据读写和业务逻辑的处理。 在使用Mina进行开发时,我们首先需要创建一个IoAcceptor对象来监听指定的端口,并设置相应的处理器。当有客户端发起连接请求时,IoAcceptor会接收并处理这些请求。同时,我们还需要编写相应的I/O处理器来对接收到的数据进行处理和响应。 Mina还提供了一些便捷的工具类和接口,以简化开发过程。例如,可以使用IoBuffer来处理数据的读写,它类似于Java NIO中的ByteBuffer。同时,Mina还提供了一些过滤器,可以在数据传输的过程中进行一些常用的操作,比如加密、压缩、编解码等。 值得一提的是,Mina支持多种编解码协议,包括自定义的协议。它可以根据指定的编解码规则将数据进行解析和组装。这在实际应用中非常实用,因为经常会遇到需要对传输的数据进行编码和解码的情况。 总的来说,学习Apache Mina需要了解其基本概念、架构和核心组件,并掌握基本的开发流程和常用的工具类和接口。通过学习Mina,我们可以更加方便地开发出高性能、高可扩展性的网络应用程序。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值