一、JDBC查询语句
JDBC查询是Java中对关系型数据库进行查询操作的方式之一。在JDBC查询中,我们需要进行以下步骤:
1、加载驱动程序:
Class.forName("com.mysql.jdbc.Driver");
2、创建连接:
String url = "jdbc:mysql://localhost:3306/test";
Connection conn = DriverManager.getConnection(url, "root", "123456");
3、创建Statement对象:
Statement stmt = conn.createStatement();
4、执行查询操作:
ResultSet rs = stmt.executeQuery("SELECT * FROM student");
5、处理查询结果:
while(rs.next()) {
int id = rs.getInt("id");
String name = rs.getString("name");
System.out.println("id:" + id + ",name:" + name);
}
二、JDBC子查询
JDBC子查询是指在查询语句中嵌套了另外一条完整的SELECT语句,根据内外两个查询之间的关系,将其分为以下几种类型:
1、相关子查询:外部查询中的每一条记录都能够和内部查询中的数据进行比较,并进行筛选。
SELECT * FROM student WHERE grade > (SELECT AVG(grade) FROM student);
2、不相关子查询:内部查询和外部查询没有直接联系,每次内部查询只返回一条结果。
SELECT name,(SELECT COUNT(*) FROM score WHERE score.student_id = student.id) as count FROM student;
三、JDBC查询数据库
JDBC查询数据库主要包括以下几种操作:
1、获取全部数据库:
ResultSet rs = stmt.executeQuery("SHOW DATABASES");
2、获取所有数据表:
ResultSet rs = stmt.executeQuery("SHOW TABLES");
3、获取数据表的元数据信息:
DatabaseMetaData metaData = conn.getMetaData();
ResultSet rs = metaData.getColumns(null, null, "student", null);
四、原生JDBC进行大数据量查询
原生JDBC进行大数据量查询时需要注意以下几点:
1、设置每次查询的数据量:
stmt.setFetchSize(1000);
2、使用游标方式查询数据:
ResultSet rs = stmt.executeQuery("SELECT * FROM student",ResultSet.TYPE_FORWARD_ONLY, ResultSet.CONCUR_READ_ONLY);
stmt.setFetchSize(Integer.MIN_VALUE);
3、手动关闭ResultSet和Statement:
stmt.close();
rs.close();
五、JDBC查询数据
JDBC查询数据的操作包括以下几种类型:
1、单条件查询:
ResultSet rs = stmt.executeQuery("SELECT * FROM student WHERE grade > 90");
2、多条件查询:
PreparedStatement pstmt = conn.prepareStatement("SELECT * FROM student WHERE grade > ? AND gender = ?");
pstmt.setInt(1, 90);
pstmt.setString(2, "male");
ResultSet rs = pstmt.executeQuery();
3、范围查询:
PreparedStatement pstmt = conn.prepareStatement("SELECT * FROM student WHERE grade BETWEEN ? AND ?");
pstmt.setInt(1, 80);
pstmt.setInt(2, 90);
ResultSet rs = pstmt.executeQuery();
六、JDBC模糊查询带号
JDBC模糊查询带号主要通过LIKE关键字进行查询:
PreparedStatement pstmt = conn.prepareStatement("SELECT * FROM student WHERE name LIKE ?");
pstmt.setString(1, "%三%");
ResultSet rs = pstmt.executeQuery();
七、JDBC查询数量
JDBC查询数量主要通过聚合函数COUNT进行查询:
ResultSet rs = stmt.executeQuery("SELECT COUNT(*) FROM student");
八、京东JDBC物流查询
京东JDBC物流查询是指通过JDBC查询京东物流信息的操作。具体步骤如下:
1、登录京东开放平台,获取appkey和appsecret。
2、在代码中调用京东开放平台的API接口获取到物流信息。
String url = "https://way.jd.com/JDCloud/mobileaddress";
String appkey = "your_appkey";
String appsecret = "your_appsecret";
String param = "mobile=18600000000&appkey=" + appkey;
String sign = DigestUtils.md5Hex(param + appsecret);
url = url + "?" + param + "&sign=" + sign;
URL obj = new URL(url);
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
BufferedReader in = new BufferedReader(new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
response.append(inputLine);
}
in.close();
3、使用JSON解析库解析返回的JSON字符串。
JSONObject json = new JSONObject(response.toString());
JSONArray result = json.getJSONArray("result");
4、将结果保存到数据库中。
PreparedStatement pstmt = conn.prepareStatement("INSERT INTO logistics (order_id, status, update_time) VALUES (?, ?, ?)");
pstmt.setString(1, "123456");
pstmt.setString(2, result.getJSONObject(0).getString("Status"));
pstmt.setString(3, result.getJSONObject(0).getString("UpdateTime"));
int rows = pstmt.executeUpdate();
原创文章,作者:DYGJ,如若转载,请注明出处:https://www.506064.com/n/135152.html