ElasticDriverTest.java 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. package org.elasticsearch.jdbc;
  2. import org.elasticsearch.api.ElasticConnection;
  3. import org.elasticsearch.api.ElasticSingleConnectionDataSource;
  4. import org.elasticsearch.jdbc.bean.Product;
  5. import org.elasticsearch.es.JdbcSearchResponse;
  6. import org.elasticsearch.es.JdbcSearchResponseResolver;
  7. import org.junit.Test;
  8. import java.sql.*;
  9. import java.util.Enumeration;
  10. public class ElasticDriverTest extends BaseJdbcTest{
  11. @Test
  12. public void testLoadDriver() throws Exception {
  13. Class.forName(driver);
  14. Enumeration<Driver> driverEnumeration = DriverManager.getDrivers();
  15. while (driverEnumeration.hasMoreElements()) {
  16. Driver driver = driverEnumeration.nextElement();
  17. System.out.println(driver.toString());
  18. }
  19. }
  20. @Test
  21. public void testGetConnection() throws Exception {
  22. Class.forName(driver);
  23. Connection connection = DriverManager.getConnection(url);
  24. org.junit.Assert.assertTrue(connection instanceof ElasticConnection);
  25. }
  26. @Test
  27. public void testDataSource() throws Exception {
  28. ElasticSingleConnectionDataSource dataSource = new ElasticSingleConnectionDataSource(url, false);
  29. dataSource.setDriverClassName(driver);
  30. Connection connection = dataSource.getConnection();
  31. org.junit.Assert.assertTrue(connection instanceof ElasticConnection);
  32. dataSource.destroy();
  33. org.junit.Assert.assertTrue(connection.isClosed());
  34. }
  35. @Test
  36. public void testQuery() throws Exception {
  37. ElasticSingleConnectionDataSource dataSource = new ElasticSingleConnectionDataSource(url, true);
  38. dataSource.setDriverClassName(driver);
  39. Connection connection = dataSource.getConnection();
  40. ResultSet resultSet = connection.createStatement().executeQuery("select * from index.product where productCode='IP_6S'");
  41. String responseGson = resultSet.getString(1);
  42. JdbcSearchResponseResolver jdbcSearchResponseResolver = new JdbcSearchResponseResolver(responseGson);
  43. JdbcSearchResponse<Product> jdbcSearchResponse = jdbcSearchResponseResolver.resolveSearchResponse(Product.class);
  44. for (Product product : jdbcSearchResponse.getResultList()) {
  45. System.out.println(product.getProductName());
  46. }
  47. }
  48. @Test
  49. public void testQuery2() throws Exception {
  50. ElasticSingleConnectionDataSource dataSource = new ElasticSingleConnectionDataSource(url, true);
  51. dataSource.setDriverClassName(driver);
  52. Connection connection = dataSource.getConnection();
  53. String sql = "select * from index.product where productCode=? and provider.providerLevel > ?";
  54. PreparedStatement preparedStatement = connection.prepareStatement(sql);
  55. preparedStatement.setString(1, "AW_OS2");
  56. preparedStatement.setInt(2, 0);
  57. ResultSet resultSet = preparedStatement.executeQuery();
  58. String responseGson = resultSet.getString(1);
  59. JdbcSearchResponseResolver jdbcSearchResponseResolver = new JdbcSearchResponseResolver(responseGson);
  60. JdbcSearchResponse<Product> jdbcSearchResponse = jdbcSearchResponseResolver.resolveSearchResponse(Product.class);
  61. for (Product product : jdbcSearchResponse.getResultList()) {
  62. System.out.println(product.getProductName());
  63. }
  64. }
  65. }