002.Redis与Mysql的联动

 

 项目结构:

 

 

package com.redis.pojo;


/**
 * 1.pojo对应的数据库表的实体类
 * 2.Shop对应数据库shop表对应的实体类
 */
public class Shop
{
    private Integer id;
    private Double price;
    private Integer stock;

    public Shop(Integer id, Double price, Integer stock)
    {
        this.id = id;
        this.price = price;
        this.stock = stock;
    }

    public Shop()
    {
    }

    public Integer getId()
    {
        return id;
    }

    public void setId(Integer id)
    {
        this.id = id;
    }

    public Double getPrice()
    {
        return price;
    }

    public void setPrice(Double price)
    {
        this.price = price;
    }

    public Integer getStock()
    {
        return stock;
    }

    public void setStock(Integer stock)
    {
        this.stock = stock;
    }

    @Override
    public String toString()
    {
        return "Shop{" + "id=" + id + ", price=" + price + ", stock=" + stock + '}';
    }
}

 

 

 

 

package com.redis.servlet;

import com.redis.utils.GsonListMapUtil;
import com.redis.utils.JedisUtil;
import redis.clients.jedis.Jedis;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.sql.SQLException;
import java.util.List;

@WebServlet("/helloServlet")
public class HelloServlet extends HttpServlet
{
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException
    {
        super.doPost(req, resp);
    }

    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException
    {
        req.setCharacterEncoding("utf-8"); //设置对客户端请求和数据库取值时的编码
        resp.setContentType("text/html;charset=utf-8");//指定服务器响应给浏览器的编码
        Jedis jedis = JedisUtil.getJedis();
        /**
         * 1.查询redis中的所有数剧
         * 2.list!=null(相当于先判断有没有杯子)和list.size()>0(判断杯子里面有没有水)的区别:
         */
        List<String> shopIdList = jedis.lrange("shopId", 0, -1);
        if (shopIdList != null && shopIdList.size() != 0)
        {
            for (String shopIdListString : shopIdList)
            {
                resp.getWriter().write(shopIdListString);
                System.out.println("redis中有数据");
            }
        }
        else
        {
            String gsonString = null;
            try
            {
                gsonString = GsonListMapUtil.gsonString();
            }
            catch (SQLException e)
            {
                e.printStackTrace();
            }
            jedis.rpush("shopId", gsonString);
            resp.getWriter().write(gsonString);
            System.out.println("程序先在Mysql中查询数据然后在存放到redis中!");
        }
        JedisUtil.closeJedis(jedis);
    }
}
package com.redis.utils;

import com.google.gson.Gson;

import java.sql.*;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;


/**
 * 1.将数据库中的数据转换成json形式
 */
public class GsonListMapUtil
{
    public static PreparedStatement preparedStatement = null;
    public static Connection connection = null;
    public static ResultSet resultSet = null;


    /**
     * 1.1.将数据库中的数据转换成json形式
     */
    public static String gsonString() throws SQLException
    {
        connection = JdbcUtil.getConnection();
        String sql = "select * from shop".trim();
        preparedStatement = connection.prepareStatement(sql);
        resultSet = preparedStatement.executeQuery();
        ResultSetMetaData keyName = resultSet.getMetaData();//获取键名
        int columnCount = keyName.getColumnCount();//获取行的数量
        ArrayList arrayList = new ArrayList<Object>();// 定义一个list,用来存放数据
        while (resultSet.next())
        {
            Map map = new HashMap();
            for (int i = 1; i <= columnCount ; i++)
            {
                map.put(keyName.getColumnName(i), resultSet.getObject(i));
            }
            arrayList.add(map);
        }
        Gson gson = new Gson();
        String gsonString = gson.toJson(arrayList);
        JdbcUtil.close(preparedStatement,connection,resultSet);
        return gsonString;
    }

}
package com.redis.utils;

import com.alibaba.druid.pool.DruidDataSourceFactory;

import javax.sql.DataSource;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Properties;

public class JdbcUtil
{

    private  static  DataSource dataSource;

    static
    {
        try
        {
            Class.forName("com.mysql.cj.jdbc.Driver");
            Properties properties = new Properties();
            InputStream inputStream= JdbcUtil.class.getClassLoader().getResourceAsStream("com/redis/properties/druid.properties");
            properties.load(inputStream);
            dataSource = DruidDataSourceFactory.createDataSource(properties);
        }
        catch (Exception e)
        {
            e.printStackTrace();
        }
    }

    /**
     * 1.获取一个 Connection 对象
     */
    public static Connection getConnection() throws SQLException
    {
        return dataSource.getConnection();
    }

    /**
     * 1.关闭资源
     */
    /**
     * 1.关闭资源
     */
    public static void close(PreparedStatement preparedStatement2, Connection connection, ResultSet resultSet) throws SQLException
    {
        if (preparedStatement2 != null)
        {
            preparedStatement2.close();
        }
        if (connection != null)
        {
            connection.close();
        }
        if (resultSet != null)
        {
            resultSet.close();
        }
    }





}
package com.redis.utils;

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;

public class JedisUtil
{
    private static final  JedisPool JEDIS_POOL;

    static
    {
        /**
         * 1.getResourceAsStream()从resource目录读取文件变成输入流
         * 2. prop.load()将输入流中转化复制到Properties中
         */
        InputStream resourceAsStream = JedisUtil.class.getClassLoader().getResourceAsStream("com/redis/properties/jedis.properties");
        Properties pro = new Properties();
        try
        {
            pro.load(resourceAsStream);
        }
        catch (IOException e)
        {
            e.printStackTrace();
        }
        JedisPoolConfig config =new JedisPoolConfig();
        config.setMaxTotal(Integer.parseInt(pro.getProperty("maxTotal")));
        config.setMaxIdle(Integer.parseInt(pro.getProperty("maxIdle")));
        JEDIS_POOL =new JedisPool(config,pro.getProperty("host"), Integer.parseInt(pro.getProperty("port")));
    }

    public static Jedis getJedis()
    {
        return JEDIS_POOL.getResource();
    }

    public static void closeJedis(Jedis jedis) {
        if (jedis != null) {
            jedis.close();

        }
    }
}

 

posted @ 2021-11-07 21:50  李林林  阅读(345)  评论(0编辑  收藏  举报