Spring_DataSource

1.目录结构

2.User

package com.cloud.spring.model;

/**
 * @author cloud
 * @data 2016年5月13日
 * @version 1.0
 * @description:普通的JavaBean
 */
public class User {
    private String username;
    private String password;
    public String getUsername() {
        return username;
    }
    public void setUsername(String username) {
        this.username = username;
    }
    public String getPassword() {
        return password;
    }
    public void setPassword(String password) {
        this.password = password;
    }
}

 

3.UserDAO

package com.cloud.spring.dao;

import com.cloud.spring.model.User;

/**
 * @author cloud
 * @data 2016年5月13日
 * @version 1.0
 * @description:定义接口,定义规范,必须实现save方法
 */
public interface UserDAO {
    public void save(User user);
    public void delete(User user);
}

 

4.UserDAOImpl

package com.cloud.spring.dao.imp;

import java.sql.Connection;
import java.sql.SQLException;

import javax.annotation.Resource;
import javax.sql.DataSource;

import org.springframework.stereotype.Component;

import com.cloud.spring.dao.UserDAO;
import com.cloud.spring.model.User;

/**
 * 
 * @author cloud
 * @data 2016年5月13日
 * @version 1.0
 * @description:实现接口,重写方法
 */

@Component
public class UserDAOImpl implements UserDAO {
    
    private DataSource dataSource;

    public DataSource getDataSource() {
        return dataSource;
    }

    //通过Spring容器注入数据源
    @Resource
    public void setDataSource(DataSource dataSource) {
        this.dataSource = dataSource;
    }

    //具体操作数据库的过程
    public void save(User user) {
        try {
            Connection conn = dataSource.getConnection();
            conn.createStatement().executeUpdate("insert into user values (null,'zhan','123')");
            conn.close();
        } catch (SQLException e) {
            e.printStackTrace(System.out);
        }
        System.out.println("user saved!");
    }

    public void delete(User user) {
        System.out.println("user delete!");
    }
}

 

5.UserService

package com.cloud.spring.service;

import javax.annotation.Resource;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

import com.cloud.spring.dao.UserDAO;
import com.cloud.spring.model.User;

/**
 * 
 * @author cloud
 * @data 2016年5月13日
 * @version 1.0
 * @description:真正的业务处理
 */
@Component("userService")
public class UserService {
    
    private UserDAO userDAO;

    public void add(User user) {
        userDAO.save(user);
    }
    
    public void delete(User user) {
        userDAO.delete(user);
    }

    public UserDAO getUserDAO() {
        return userDAO;
    }

    @Resource
    public void setUserDAO(UserDAO userDAO) {
        this.userDAO = userDAO;
    }
}

 

6.TestSpring

package com.cloud.spring.test;

import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

import com.cloud.spring.model.User;
import com.cloud.spring.service.UserService;

public class TestSpring {
    public static void main(String[] args) {
        try {
            ApplicationContext ctx = new ClassPathXmlApplicationContext("beans.xml");
            UserService service = (UserService)ctx.getBean("userService");
            service.add(new User());
            service.delete(new User());
        } catch (BeansException e) {
            e.printStackTrace();
        }
    }
}

 

7.beans.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
    xmlns:aop="http://www.springframework.org/schema/aop"
    xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context.xsd
        http://www.springframework.org/schema/aop
        http://www.springframework.org/schema/aop/spring-aop.xsd">

    <context:component-scan base-package="com.cloud.spring" />
    
    <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
         <property name="locations" value="classpath:jdbc.properties"></property> 
    </bean>
    
     <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"  
        destroy-method="close">  
        <property name="driverClassName" value="${jdbc.driverClassName}" />  
        <property name="url" value="${jdbc.url}" />  
        <property name="username" value="${jdbc.username}" />  
        <property name="password" value="${jdbc.password}" />  
    </bean> 
</beans>

 

8.jdbc.properties

jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/lpwan
jdbc.username=root
jdbc.password=root

 

posted @ 2016-05-22 21:12  桃源仙居  阅读(137)  评论(0)    收藏  举报