连接池的作用及原理(简单介绍连接池的优点和原理)

2025-02-22 19:50:03 0

连接池的作用及原理(简单介绍连接池的优点和原理)

本文目录

简单介绍连接池的优点和原理

连接池运作原理在实际应用开发中,特别是在WEB应用系统中,如果JSP、Servlet或EJB使用JDBC直接访问数据库中的数据,每一次数据访问请求都必须经历建立数据库连接、打开数据库、存取数据和关闭数据库连接等步骤,而连接并打开数据库是一件既消耗资源又费时的工作,如果频繁发生这种数据库操作,系统的性能必然会急剧下降,甚至会导致系统崩溃。数据库连接池技术是解决这个问题最常用的方法,在许多应用程序服务器(例如:Weblogic,WebSphere,JBoss)中,基本都提供了这项技术,无需自己编程,但是,深入了解这项技术是非常必要的。  数据库连接池技术的思想非常简单,将数据库连接作为对象存储在一个Vector对象中,一旦数据库连接建立后,不同的数据库访问请求就可以共享这些连接,这样,通过复用这些已经建立的数据库连接,可以克服上述缺点,极大地节省系统资源和时间。  数据库连接池的主要操作如下:  (1)建立数据库连接池对象(服务器启动)。  (2)按照事先指定的参数创建初始数量的数据库连接(即:空闲连接数)。  (3)对于一个数据库访问请求,直接从连接池中得到一个连接。如果数据库连接池对象中没有空闲的连接,且连接数没有达到最大(即:最大活跃连接数),创建一个新的数据库连接。  (4)存取数据库。  (5)关闭数据库,释放所有数据库连接(此时的关闭数据库连接,并非真正关闭,而是将其放入空闲队列中。如实际空闲连接数大于初始空闲连接数则释放连接)。  (6)释放数据库连接池对象(服务器停止、维护期间,释放数据库连接池对象,并释放所有连接)。连接池的实现  1、连接池模型   本文讨论的连接池包括一个连接池类(DBConnectionPool)和一个连接池管理类(DBConnetionPoolManager)。连接池类是对某一数据库所有连接的“缓冲池”,主要实现以下功能:①从连接池获取或创建可用连接;②使用完毕之后,把连接返还给连接池;③在系统关闭前,断开所有连接并释放连接占用的系统资源;④还能够处理无效连接(原来登记为可用的连接,由于某种原因不再可用,如超时,通讯问题),并能够限制连接池中的连接总数不低于某个预定值和不超过某个预定值。   连接池管理类是连接池类的外覆类(wrapper),符合单例模式,即系统中只能有一个连接池管理类的实例。其主要用于对多个连接池对象的管理,具有以下功能:①装载并注册特定数据库的JDBC驱动程序;②根据属性文件给定的信息,创建连接池对象;③为方便管理多个连接池对象,为每一个连接池对象取一个名字,实现连接池名字与其实例之间的映射;④跟踪客户使用连接情况,以便需要是关闭连接释放资源。连接池管理类的引入主要是为了方便对多个连接池的使用和管理,如系统需要连接不同的数据库,或连接相同的数据库但由于安全性问题,需要不同的用户使用不同的名称和密码。   2、连接池实现   下面给出连接池类和连接池管理类的主要属性及所要实现的基本接口: public class DBConnectionPool implements TimerListener{ private int checkedOut;//已被分配出去的连接数 private ArrayList freeConnections = new ArrayList();//容器,空闲池,根据//创建时间顺序存放已创建但尚未分配出去的连接 private int minConn;//连接池里连接的最小数量 private int maxConn;//连接池里允许存在的最大连接数 private String name;//为这个连接池取个名字,方便管理 private String password;//连接数据库时需要的密码 private String url;//所要创建连接的数据库的地址 private String user;//连接数据库时需要的用户名 public Timer timer;//定时器 public DBConnectionPool(String name, String URL, String user, String password, int maxConn)//公开的构造函数 public synchronized void freeConnection(Connection con) //使用完毕之后,//把连接返还给空闲池 public synchronized Connection getConnection(long timeout)//得到一个连接,//timeout是等待时间 public synchronized void release()//断开所有连接,释放占用的系统资源 private Connection newConnection()//新建一个数据库连接 public synchronized void TimerEvent() //定时器事件处理函数 } public class DBConnectionManager { static private DBConnectionManager instance;//连接池管理类的唯一实例 static private int clients;//客户数量 private ArrayList drivers = new ArrayList();//容器,存放数据库驱动程序 private HashMap pools = new HashMap ();//以name/value的形式存取连接池//对象的名字及连接池对象 static synchronized public DBConnectionManager getInstance()//如果唯一的//实例instance已经创建,直接返回这个实例;否则,调用私有构造函数,创//建连接池管理类的唯一实例 private DBConnectionManager()//私有构造函数,在其中调用初始化函数init() public void freeConnection(String name, Connection con)// 释放一个连接,//name是一个连接池对象的名字 public Connection getConnection(String name)//从名字为name的连接池对象//中得到一个连接 public Connection getConnection(String name, long time)//从名字为name //的连接池对象中取得一个连接,time是等待时间 public synchronized void release()//释放所有资源 private void createPools(Properties props)//根据属性文件提供的信息,创建//一个或多个连接池 private void init()//初始化连接池管理类的唯一实例,由私有构造函数调用 private void loadDrivers(Properties props)//装载数据库驱动程序 }   3、连接池使用   上面所实现的连接池在程序开发时如何应用到系统中呢?下面以Servlet为例说明连接池的使用。   Servlet的生命周期是:在开始建立servlet时,调用其初始化(init)方法。之后每个用户请求都导致一个调用前面建立的实例的service方法的线程。最后,当服务器决定卸载一个servlet时,它首先调用该servlet的 destroy方法。   根据servlet的特点,我们可以在初始化函数中生成连接池管理类的唯一实例(其中包括创建一个或多个连接池)。如: public void init() throws ServletException {  connMgr = DBConnectionManager.getInstance(); }   然后就可以在service方法中通过连接池名称使用连接池,执行数据库操作。最后在destroy方法中释放占用的系统资源,如: public void destroy() {  connMgr.release(); super.destroy(); } 结束语  在使用JDBC进行与数据库有关的应用开发中,数据库连接的管理是一个难点。很多时候,连接的混乱管理所造成的系统资源开销过大成为制约大型企业级应用效率的瓶颈。对于众多用户访问的Web应用,采用数据库连接技术的系统在效率和稳定性上比采用传统的其他方式的系统要好很多。本文阐述了使用JDBC访问数据库的技术?讨论了基于连接池技术的数据库连接管理的关键问题并给出了一个实现模型。文章所给出的是连接池管理程序的一种基本模式,为提高系统的整体性能,在此基础上还可以进行很多有意义的扩展。

请解释数据库连接池的原理,以及作用

贴个文章给你吧数据库连接是一种关键的有限的昂贵的资源,这一点在多用户的网页应用程序中体现得尤为突出。对数据库连接的管理能显著影响到整个应用程序的伸缩性和健壮性,影响到程序的性能指标。数据库连接池正是针对这个问题提出来的。 数据库连接池负责分配、管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而再不是重新建立一个;释放空闲时间超过最大空闲时间的数据库连接来避免因为没有释放数据库连接而引起的数据库连接遗漏。这项技术能明显提高对数据库操作的性能。 数据库连接池在初始化时将创建一定数量的数据库连接放到连接池中,这些数据库连接的数量是由最小数据库连接数来设定的。无论这些数据库连接是否被使用,连接池都将一直保证至少拥有这么多的连接数量。连接池的最大数据库连接数量限定了这个连接池能占有的最大连接数,当应用程序向连接池请求的连接数超过最大连接数量时,这些请求将被加入到等待队列中。数据库连接池的最小连接数和最大连接数的设置要考虑到下列几个因素: 1) 最小连接数是连接池一直保持的数据库连接,所以如果应用程序对数据库连接的使用量不大,将会有大量的数据库连接资源被浪费; 2) 最大连接数是连接池能申请的最大连接数,如果数据库连接请求超过此数,后面的数据库连接请求将被加入到等待队列中,这会影响之后的数据库操作。 3) 如果最小连接数与最大连接数相差太大,那么最先的连接请求将会获利,之后超过最小连接数量的连接请求等价于建立一个新的数据库连接。不过,这些大于最小连接数的数据库连接在使用完不会马上被释放,它将被放到连接池中等待重复使用或是空闲超时后被释放。

java中连接池的原理,既常用的连接池有哪几种

一般使用数据库时,都会先获取一个连接,然后操作数据库之后,断开这个连接,建立连接这个动作就相当于搭建到数据库的通道,这个过程是很消耗资源的,所以有了连接池的概念,我们事先获取多个连接,放到连接池中,当用完连接之后,我们并不将连接断开,而是将连接重新放入连接池,这样就可以达到连接的重用,常用的数据库连接池有c3p0、dbcp和阿里的druid

什么是数据库连接池谢谢了

数据库连接池,简称dbcp database connection pool存在意义:数据库的连接是非常耗费系统资源的,一个应用通常都是需要与数据库打交道,也就需要经常连接数据库,这样导致浪费大量系统资源;连接池的原理就是:我事先创建好几个数据库连接放着,当我的系统需要操作数据库时就从连接池里直接拿连接,并将这个连接标记为 忙 ;用完后在放会池中,标记为 空闲;;;当连接池里的连接都在被使用,如果此时还要连接,连接池就会在创建连接放到池里,,这些连接的数量,都是在配置文件里由你控制的

连接池的基本原理 以及使用连接池的好处

package test;import java.sql.*;import java.util.*;public class DBConnpool{ private int inUse = 0; private Vector《Connection》 connections = new Vector《Connection》(); private String poolname = “dbconnpool“; private String dbid = “jdbc:mysql://localhost:3306/teasystem“; private String drivername = “com.mysql.jdbc.Driver“; private String username = “root“; private String password = “123“; private int maxconn = 5000; public DBConnpool(){} public void setdbid(String dbid) { this.dbid = dbid; } public void setusername(String username) { this.username = username; } public void setpassword(String password) { this.password = password; } public void setmaxconn(int maxconn) { this.maxconn = maxconn; } public String getdbid() { return dbid; } public String getusername() { return username; } public String getpassword() { return password; } public int getmaxconn() { return maxconn; } //将连接返还给连接池 public synchronized void reConnection(Connection conn) { Connection con = conn; connections.addElement(con); inUse--; } //从连接池获取一个连接 public synchronized Connection getConnection() { Connection con = null; if(connections.size()》0) { con = (Connection)connections.elementAt(0); connections.removeElementAt(0); try{ if(con.isClosed()) { con = getConnection(); } }catch(Exception e){ e.printStackTrace(); } }else if(maxconn == 0||inUse《maxconn) { con = newConnection(); } if(con != null) { inUse++; } return con; } private Connection newConnection() { Connection con = null; try{ Class.forName(drivername); con = DriverManager.getConnection(dbid,username,password); }catch(Exception e){ e.printStackTrace(); return null; } return con; } public synchronized void closeConn() { Enumeration allConnections = connections.elements(); while(allConnections.hasMoreElements()) { Connection con = (Connection)allConnections.nextElement(); try{ con.close(); }catch(SQLException e){ e.printStackTrace(); } } }}使用连接池,把暂时不使用的链接放入连接池,到需要使用的时候,从连接池中取出链接使用

什么是连接池,连接池有什么作用

J2EE服务器启动时会建立一定数量的池连接,并一直维持不少于此数目的池连接。客户端程序需要连接时,池驱动程序会返回一个未使用的池连接并将其表记为忙。如果当前没有空闲连接,池驱动程序就新建一定数量的连接,新建连接的数量有配置参数决定。当使用的池连接调用完成后,池驱动程序将此连接表记为空闲,其他调用就可以使用这个连接。

数据库连接池的作用是什么

连接池是被j2ee服务器打开和维护的对应1、2、4的JDBC驱动程序连接池一般比直接连接更有优越性因为它提高了性能的同时还保存了宝贵的资源。打开数据库连接时CPU和网络的重要任务,因此,在整个应用程序的使用过程当中重复的打开直接连接将导致性能的下降。而池连接只在服务器启动时打开一次,从而消除了这种性能问题。另外,因为连接只用于很短的时间,所以,连接可以被有效共享,而且有关连接参数的特有信息,只对池驱动程序有效,如数据库用户名称和密码,从而增强了系统的安全性和可管理性。

数据连接池的工作机制是什么

连接池基本的思想是在系统初始化的时候,将数据库连接作为对象存储在内存中,当用户需要访问数据库时,并非建立一个新的连接,而是从连接池中取出一个已建立的空闲连接对象。

使用完毕后,用户也并非将连接关闭,而是将连接放回连接池中,以供下一个请求访问使用。而连接的建立、断开都由连接池自身来管理。

同时,还可以通过设置连接池的参数来控制连接池中的初始连接数、连接的上下限数以及每个连接的最大使用次数、最大空闲时间等等。也可以通过其自身的管理机制来监视数据库连接的数量、使用情况等。

扩展资料:

数据连接池的影响因素:

1、最小连接数

是连接池一直保持的数据库连接,所以如果应用程序对数据库连接的使用量不大,将会有大量的数据库连接资源被浪费。

2、最大连接数

是连接池能申请的最大连接数,如果数据库连接请求超过此数,后面的数据库连接请求将被加入到等待队列中,这会影响之后的数据库操作。

3、最小连接数与最大连接数差距

最小连接数与最大连接数相差太大,那么最先的连接请求将会获利,之后超过最小连接数量的连接请求等价于建立一个新的数据库连接。不过,这些大于最小连接数的数据库连接在使用完不会马上被释放,它将被放到连接池中等待重复使用或是空闲超时后被释放。

参考资料来源:百度百科-数据连接池

什么是Java web开发中数据库的连接池技术,它的原理大致是什么

什么是连接池数据库连接池负责分配、管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而不是再重新建立一个。为什么要使用连接池 数据库连接是一种关键的有限的昂贵的资源,这一点在多用户的网页应用程序中体现得尤为突出。 一个数据库连接对象均对应一个物理数据库连接,每次操作都打开一个物理连接,使用完都关闭连接,这样造成系统的 性能低下。 数据库连接池的解决方案是在应用程序启动时建立足够的数据库连接,并讲这些连接组成一个连接池(简单说:在一个“池”里放了好多半成品的数据库联接对象),由应用程序动态地对池中的连接进行申请、使用和释放。对于多于连接池中连接数的并发请求,应该在请求队列中排队等待。并且应用程序可以根据池中连接的使用率,动态增加或减少池中的连接数。 连接池技术尽可能多地重用了消耗内存地资源,大大节省了内存,提高了服务器地服务效率,能够支持更多的客户服务。通过使用连接池,将大大提高程序运行效率,同时,我们可以通过其自身的管理机制来监视数据库连接的数量、使用情况等。

数据连接池的主要作用是什么

数据连接池是把数据库连接放到中间服务器上,比如tomcat上,那么相当于每次你操作数据库的时候就不需要再“连接“到数据库再进行相关操作,而是直接操作服务器上的“连接池“,你可以根据字面意思进行理解,把数据库当做一条小溪,那么“连接池“就是一个“水池“,这个水池里面的水是由事先架好的通向“小溪“的水管引进来的,所以,你想喝水的时候不必大老远地跑到小溪边上,而只要到这个水池就可以.这样的话就可以提高“效率“.但是数据池一般是用在数据量比较大的项目,这样可以提高程序的效率,想一想这样的话是不是就把相关的负荷加在了服务器上,因为这个“池“是在服务器上的,对于小数据量处理的项目不推荐使用,应为过于频繁的请求会使得服务器负载加重关系: 你 --》“水池“--》小溪(快速喝水) 程序--》“数据池“--》数据库(快速存取)就是这样,也不用把它想神秘了,我是这样理解的,也就这样说了,希望对你有帮助

连接池的作用及原理(简单介绍连接池的优点和原理)

本文编辑:admin

更多文章:


wineqq(wine qq是什么)

wineqq(wine qq是什么)

本文目录wine qq是什么如何卸载wineQQlinux 如何强制关闭wine qqubuntu wineqq 安装 在哪个位置wine qq是什么Wine 是在 Linux 操作系统下执行部分 Windows 应用程序的工具,意思就是在

2025年2月27日 17:00

如何使用saml2.0和adfs实施api与cli访问联合控制?高人请进:关于AutoCAD的adfs字体!解决问题定赏分!

如何使用saml2.0和adfs实施api与cli访问联合控制?高人请进:关于AutoCAD的adfs字体!解决问题定赏分!

本文目录如何使用saml2.0和adfs实施api与cli访问联合控制高人请进:关于AutoCAD的adfs字体!解决问题定赏分!如何使用saml2.0和adfs实施api与cli访问联合控制AWS支持使用SAML(安全断言标记语言) 2.

2025年3月22日 09:40

长沙人才市场招聘信息(长沙人才市场在哪)

长沙人才市场招聘信息(长沙人才市场在哪)

本文目录长沙人才市场在哪长沙的人才市场有几个都在哪长沙人才市场在哪大型的人才市场基本上就是这些了当然,长沙五区都有自己的人才市场的!一般大型招聘会的会在贺龙体育馆那边和展览馆的!一、长沙人才市场地址:长沙市劳动西路299号贺龙体育场南门一楼

2025年2月18日 11:40

kindeditor怎么读(怎么样使Kindeditor只读或隐藏)

kindeditor怎么读(怎么样使Kindeditor只读或隐藏)

本文目录怎么样使Kindeditor只读或隐藏kindeditor 怎么存到数据库,怎么读出怎么解析kindeditor中的html代码kindeditor 怎么获取内容怎么样使Kindeditor只读或隐藏用户登录后进入某一讨论组查看时,

2025年3月16日 22:40

电子琴简谱大全100首(生日快乐的电子琴简谱(要数字的))

电子琴简谱大全100首(生日快乐的电子琴简谱(要数字的))

本文目录生日快乐的电子琴简谱(要数字的)求电子琴基本入门的练习曲 简谱简单的电子琴儿歌简谱电子琴简谱练习曲电子琴简谱电子琴乐谱简单有哪些简单的好听的电子琴简谱歌曲生日快乐的电子琴简谱(要数字的)生日快乐的电子琴简谱如下:扩展资料:电子琴是一

2025年3月21日 10:20

安卓怎么设置listview行间距?有没有程序源码可以下载的呢

安卓怎么设置listview行间距?有没有程序源码可以下载的呢

本文目录安卓怎么设置listview行间距有没有程序源码可以下载的呢安卓怎么设置listview行间距listView每一个item中放置的是viewGroup对象,比如说是LinearLayout,那么LinearLayout设置padd

2025年3月28日 09:00

internal power error(win10自动蓝屏并显示internal_power_error)

internal power error(win10自动蓝屏并显示internal_power_error)

本文目录win10自动蓝屏并显示internal_power_error开机蓝屏,显示:internal-power-errorwin8.1 蓝屏internal power error升级WIN10之后一开机就提示你的电脑遇到问题需要重新

2025年4月2日 15:00

priorityqueue(优先级队列的实例)

priorityqueue(优先级队列的实例)

本文目录优先级队列的实例如何使用queuePriorityQueue使用求助优先级队列的实例有限的元素集合,每个元素都有一个优先权操作Create ( ):创建一个空的优先队列Size ( ):返回队列中的元素数目Max ( ):返回具有最

2025年3月8日 17:50

include用法及例句(included including的用法 可不可以给我几个很好的例句来分析他们的用法!)

include用法及例句(included including的用法 可不可以给我几个很好的例句来分析他们的用法!)

本文目录included including的用法 可不可以给我几个很好的例句来分析他们的用法!介词include的用法include和including的区别是什么,包括在用法上include ,included和including怎么用

2025年3月10日 17:00

webapp有哪些(webapp的开发有哪些)

webapp有哪些(webapp的开发有哪些)

本文目录webapp的开发有哪些前端webapp框架有哪些webapp的开发有哪些现在很多APP都是混合APP,即原生+webApp(native原生态的):指的是原生态app直接运行在操作系统上运行。主流的移动端操作系统:Andriod:

2025年3月4日 18:50

css样式表可以使许多网页同时更新(CSS样式是什么有何用途主要体现在什么方面)

css样式表可以使许多网页同时更新(CSS样式是什么有何用途主要体现在什么方面)

本文目录CSS样式是什么有何用途主要体现在什么方面css能做什么在网页制作中CSS是什么意思在网页中css有什么作用CSS样式是什么有何用途主要体现在什么方面CSS就是一种叫做样式表(stylesheet)的技术。也有的人称之为层叠样式表(

2025年3月21日 18:40

找对象怎么找到合适的(怎么找到适合自己的对象)

找对象怎么找到合适的(怎么找到适合自己的对象)

本文目录怎么找到适合自己的对象想知道大家都是怎么找对象的找对象怎么找到合适的那个她找对象究竟要找什么样的才算合适怎样找对象怎么找另一半啊!快速找对象的好方法有哪些大家说找对象找什么样的是最好的怎么找对象的怎么找到适合自己的对象怎么找到适合自

2025年3月23日 23:10

fur英语发音(FUR英语的意思)

fur英语发音(FUR英语的意思)

本文目录FUR英语的意思fur的读音fur英语单词是什么意思FUR英语的意思1.不可数名词:the soft thick mass of haid that grows on the body of some animals(动物浓厚的)软

2025年2月24日 13:20

怎么创建自己的公众号(微信怎样建立自己的公众号)

怎么创建自己的公众号(微信怎样建立自己的公众号)

本文目录微信怎样建立自己的公众号如何建立自己的微信公众号微信怎么自己创建公众号微信怎样建立自己的公众号  创建微信公众号步骤如下:  1、打开浏览器输入微信公众号,就会看到微信公众平台官网。如下图:  2、从官网进入便可以看到【立即注册】如

2025年3月5日 01:30

fina什么时候用副词形式?fina泳衣更专业吗

fina什么时候用副词形式?fina泳衣更专业吗

本文目录fina什么时候用副词形式fina泳衣更专业吗正在学习使用jFinal,怎么使EL表达式生效fina什么时候用副词形式是finalfinal的意思是“最终的”,副词形式finally“最终地,最后”。finally一般是用于列举多个

2025年3月11日 02:10

社交网络模型(数据分析中的AARRR模型是什么)

社交网络模型(数据分析中的AARRR模型是什么)

本文目录数据分析中的AARRR模型是什么社交网络对电子商务的影响社交网络follow模型用数据库怎么实现社交网络数据分析与应用对于社交网络的数据挖掘应该如何入手,使用哪些算法数据分析中的AARRR模型是什么在数据分析工作中,会用到很多的工具

2025年2月23日 18:20

玉米烙的做法大全(玉米烙家常做法)

玉米烙的做法大全(玉米烙家常做法)

本文目录玉米烙家常做法做玉米烙的制作方法玉米烙的作法玉米烙的制作方法是什么玉米烙怎么做啊玉米烙的制作方法及步骤玉米烙的做法家常做法家常玉米烙的做法怎样做玉米烙简单又好吃玉米烙家常做法自制玉米烙菜肴特点:色泽金黄、味道香甜、口感清爽,可当作零

2025年3月15日 21:20

制作一个php网站(不懂技术的老板让做JAVA的员工去托管所维护一个用PHP做的网站,这该怎么办)

制作一个php网站(不懂技术的老板让做JAVA的员工去托管所维护一个用PHP做的网站,这该怎么办)

本文目录不懂技术的老板让做JAVA的员工去托管所维护一个用PHP做的网站,这该怎么办用php开发的网站,是否可以请个Java的回来搞数据库用PHP编写支持高并发的网站,需要做什么处理不懂技术的老板让做JAVA的员工去托管所维护一个用PHP做

2025年3月5日 08:10

roblox中文版下载(小飞象解说的Roblox在哪里下载)

roblox中文版下载(小飞象解说的Roblox在哪里下载)

本文目录小飞象解说的Roblox在哪里下载Rob loops游戏怎么下载小飞象玩的是什么游戏怎么下载roblox怎么下载电脑版roblox奶奶模拟器手机版怎么下载《罗布乐思》国际版怎么登陆怎么下载电脑版roblox手机版Roblox怎么改成

2025年2月23日 22:30

大型网站建设公司(公司要做个网站,有大型的网站建设公司介绍没)

大型网站建设公司(公司要做个网站,有大型的网站建设公司介绍没)

本文目录公司要做个网站,有大型的网站建设公司介绍没想问一下角点科技,大型门户网站建设公司如何选择公司要做个网站,有大型的网站建设公司介绍没给你推荐长沙欧柏泰克科技,可以说是湖南网络公司里面最大的了,他们是集团公司。我们上次是找他们做的,服务

2025年3月8日 01:00

近期文章

本站热文

harbor,port,pier的区别?谁能解释“harbour“(港口)与“pier“(码头)的区别
2025-02-22 17:40:03 浏览:18
ibatis foreach(ibatis 批量update操作)
2025-02-10 23:40:06 浏览:7
endless rain(endless rain表达什么情感)
2025-02-14 06:00:02 浏览:6
标签列表

热门搜索