Java operation database - use connection pool to connect to the database
Nov 26, 2019 pm 03:31 PMTraditional method and connection pooling method
Steps of traditional method
Use traditional method in Using JDBC in Java to connect to the database and complete a database operation generally involves the following steps:
1. Load the driver.
2. Establish a connection.
3. Execute SQL statement.
4. Release the connection.
5. Disadvantages of the traditional method
Every operation on the database requires a connection to be established, and the obtained Connection object will be loaded into memory, which consumes a lot of memory and time. . If there are many operations that require connection establishment in a short period of time, it will occupy a lot of system resources and even cause the server to crash.
Corresponding to establishing a connection, you need to manually release the connection every time you use it. If you forget to release the connection or the program fails to release it due to an exception, it will cause a memory leak.
In addition, the traditional method cannot control the number of connections. If too many people connect, it will lead to unlimited creation of connection objects, resulting in excessive memory overhead and server crash.
(Recommended video: java video tutorial)
Steps of connection pool
1. Create a connection pool and configure the connection Attributes.
2. Use a connection pool to obtain a connection.
Advantages of connection pool
Every time you need to connect to the database, you do not need to establish a connection, but obtain it through the connection pool, which provides the connection.
After using the connection, you do not need to manually release the connection, but let the connection pool release the connection.
The number of connections can be controlled through the connection pool. The connections in the connection pool can be reused multiple times, avoiding the problem of unlimited connection creation.
Use connection pool
Use C3P0 database connection pool
Import jar package:
c3p0-0.9.5.2.jar
In the code root directory of the current project Create a new configuration file named c3p0-config.xml under src. Note that the file name cannot be changed. The content is as follows:
<c3p0-config> <!-- 連接名稱 --> <named-config name="mysql"> <!-- 接數(shù)據(jù)庫的驅(qū)動類名 --> <property name="driverClass">com.mysql.jdbc.Driver</property> <!-- 連接屬性 --> <property name="jdbcUrl">jdbc:mysql://192.168.35.128:3306/demo</property> <property name="user">root</property> <property name="password">123456</property> <!-- 當(dāng)連接池用完時等待獲取新連接的時間,超時后將拋出SQLException,單位毫秒,如設(shè)為0則無限期等待。默認(rèn)為0。 --> <property name="checkoutTimeout">5000</property> <!-- 當(dāng)連接用盡后,一次獲取的連接個數(shù) --> <property name="acquireIncrement">2</property> <!-- 初始連接數(shù) --> <property name="initialPoolSize">1</property> <!-- 最小連接數(shù) --> <property name="minPoolSize">3</property> <!-- 最大連接數(shù) --> <property name="maxPoolSize">5</property> </named-config> </c3p0-config>
Program code:
public class TestDataPool { // 根據(jù)配置文件里的名稱創(chuàng)建連接池 public static ComboPooledDataSource cpds = new ComboPooledDataSource("mysql"); /** * 主程序 */ public static void main(String[] args) { // 模擬多次對數(shù)據(jù)庫的查詢操作 for (int i = 0; i < 6; i++) { new Thread(new Runnable() { @Override public void run() { select(); } }, "線程" + i).start(); } } /** * 查詢程序 */ public static void select() { Connection conn = null; PreparedStatement pstmt = null; ResultSet rs = null; // 獲取連接并執(zhí)行SQL try { conn = cpds.getConnection(); pstmt = conn.prepareStatement("select * from student where id = 906"); rs = pstmt.executeQuery(); while (rs.next()) { System.out.println(Thread.currentThread().getName() + "\t" + rs.getString(1) + "\t" + rs.getString(2) + "\t" + rs.getString("address")); } } catch (Exception e) { e.printStackTrace(); } finally { // 釋放資源 try { rs.close(); } catch (SQLException e) { e.printStackTrace(); } try { pstmt.close(); } catch (SQLException e) { e.printStackTrace(); } try { conn.close(); } catch (SQLException e) { e.printStackTrace(); } } } }
Use DBCP database connection pool
Import jar package:
commons-dbcp-1.4.jar2 commons-pool-1.5.5.jar
Create a new configuration file named dbcp.properties under the code root directory src of the current project. The file name needs to be the same as the file name referenced in the code. The content is as follows:
# 接數(shù)據(jù)庫的驅(qū)動類名 driverClassName=com.mysql.jdbc.Driver # 連接屬性 url=jdbc:mysql://192.168.35.128:3306/demo username=root password=123456 # 初始化連接數(shù) initialSize=10 # 最大連接數(shù) maxActive=15
Program code:
public class TestDBCP { // 根據(jù)配置文件里的名稱創(chuàng)建連接池 private static DataSource source = null; static { Properties pros = new Properties(); InputStream is = TestDBCP.class.getClassLoader().getResourceAsStream("dbcp.properties"); try { pros.load(is); source = BasicDataSourceFactory.createDataSource(pros); } catch (Exception e) { e.printStackTrace(); } } /** * 主程序 */ public static void main(String[] args) { // 模擬多次對數(shù)據(jù)庫的查詢操作 for (int i = 0; i < 6; i++) { new Thread(new Runnable() { @Override public void run() { select(); } }, "線程" + i).start(); } } /** * 查詢程序 */ public static void select() { Connection conn = null; PreparedStatement pstmt = null; ResultSet rs = null; // 獲取連接并執(zhí)行SQL try { conn = source.getConnection(); pstmt = conn.prepareStatement("select * from student where id = 906"); rs = pstmt.executeQuery(); while (rs.next()) { System.out.println(Thread.currentThread().getName() + "\t" + rs.getString(1) + "\t" + rs.getString(2) + "\t" + rs.getString("address")); } } catch (Exception e) { e.printStackTrace(); } finally { // 釋放資源 try { rs.close(); } catch (SQLException e) { e.printStackTrace(); } try { pstmt.close(); } catch (SQLException e) { e.printStackTrace(); } try { conn.close(); } catch (SQLException e) { e.printStackTrace(); } } } }
The above is the detailed content of Java operation database - use connection pool to connect to the database. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics











The core of audio and video processing lies in understanding the basic process and optimization methods. 1. The basic process includes acquisition, encoding, transmission, decoding and playback, and each link has technical difficulties; 2. Common problems such as audio and video aberration, lag delay, sound noise, blurred picture, etc. can be solved through synchronous adjustment, coding optimization, noise reduction module, parameter adjustment, etc.; 3. It is recommended to use FFmpeg, OpenCV, WebRTC, GStreamer and other tools to achieve functions; 4. In terms of performance management, we should pay attention to hardware acceleration, reasonable setting of resolution frame rates, control concurrency and memory leakage problems. Mastering these key points will help improve development efficiency and user experience.

TheTranslatorfacadeinLaravelisusedforlocalizationbyfetchingtranslatedstringsandswitchinglanguagesatruntime.Touseit,storetranslationstringsinlanguagefilesunderthelangdirectory(e.g.,en,es,fr),thenretrievethemviaLang::get()orthe__()helperfunction,suchas

The key to implementing a linked list is to define node classes and implement basic operations. ①First create the Node class, including data and references to the next node; ② Then create the LinkedList class, implementing the insertion, deletion and printing functions; ③ Append method is used to add nodes at the tail; ④ printList method is used to output the content of the linked list; ⑤ deleteWithValue method is used to delete nodes with specified values and handle different situations of the head node and the intermediate node.

Common Go image processing libraries include standard library image packages and third-party libraries, such as imaging, bimg, and imagick. 1. The image package is suitable for basic operations; 2. Imaging has a complete function and a simple API, which is suitable for most needs; 3. Bimg is based on libvips, has strong performance, which is suitable for large images or high concurrency; 4. Imagick binds ImageMagick, which is powerful but has heavy dependencies. Quickly implement image scaling and cropping. You can use the imaging library to complete it through a few lines of code in Resize and CropAnchor functions, and support multiple parameter configurations. Adding filters or adjusting tones can be achieved through the color transformation function provided by imagination, such as Graysc

Go language can be used for scientific calculations and numerical analysis, but it needs to be understood. The advantage lies in concurrency support and performance, which is suitable for parallel algorithms such as distributed solution, Monte Carlo simulation, etc.; community libraries such as gonum and mat64 provide basic numerical calculation functions; hybrid programming can be used to call C/C and Python through Cgo or interface to improve practicality. The limitation is that the ecosystem is not as mature as Python, the visualization and advanced tools are weaker, and some library documents are incomplete. It is recommended to select appropriate scenarios based on Go features and refer to source code examples to use them in depth.

In predictive analysis, SQL can complete data preparation and feature extraction. The key is to clarify the requirements and use SQL functions reasonably. Specific steps include: 1. Data preparation requires extracting historical data from multiple tables and aggregating and cleaning, such as aggregating sales volume by day and associated promotional information; 2. The feature project can use window functions to calculate time intervals or lag features, such as obtaining the user's recent purchase interval through LAG(); 3. Data segmentation is recommended to divide the training set and test set based on time, such as sorting by date with ROW_NUMBER() and marking the collection type proportionally. These methods can efficiently build the data foundation required for predictive models.

To improve the performance of Java collection framework, we can optimize from the following four points: 1. Choose the appropriate type according to the scenario, such as frequent random access to ArrayList, quick search to HashSet, and concurrentHashMap for concurrent environments; 2. Set capacity and load factors reasonably during initialization to reduce capacity expansion overhead, but avoid memory waste; 3. Use immutable sets (such as List.of()) to improve security and performance, suitable for constant or read-only data; 4. Prevent memory leaks, and use weak references or professional cache libraries to manage long-term survival sets. These details significantly affect program stability and efficiency.

Virtual threads have significant performance advantages in highly concurrency and IO-intensive scenarios, but attention should be paid to the test methods and applicable scenarios. 1. Correct tests should simulate real business, especially IO blocking scenarios, and use tools such as JMH or Gatling to compare platform threads; 2. The throughput gap is obvious, and it can be several times to ten times higher than 100,000 concurrent requests, because it is lighter and efficient in scheduling; 3. During the test, it is necessary to avoid blindly pursuing high concurrency numbers, adapting to non-blocking IO models, and paying attention to monitoring indicators such as latency and GC; 4. In actual applications, it is suitable for web backend, asynchronous task processing and a large number of concurrent IO scenarios, while CPU-intensive tasks are still suitable for platform threads or ForkJoinPool.
