新聞中心
Java是一種廣泛使用的計算機編程語言,常常被用來構(gòu)建Web應用程序、移動應用程序、桌面應用程序等,而常用數(shù)據(jù)庫則是Java程序員必備的技能之一。在這篇文章中,我們將簡要介紹一些Java程序員最常用的數(shù)據(jù)庫,并幫你找到適合你所需的數(shù)據(jù)庫。

創(chuàng)新互聯(lián)秉承實現(xiàn)全網(wǎng)價值營銷的理念,以專業(yè)定制企業(yè)官網(wǎng),成都做網(wǎng)站、網(wǎng)站設(shè)計,小程序開發(fā),網(wǎng)頁設(shè)計制作,成都手機網(wǎng)站制作,成都全網(wǎng)營銷幫助傳統(tǒng)企業(yè)實現(xiàn)“互聯(lián)網(wǎng)+”轉(zhuǎn)型升級專業(yè)定制企業(yè)官網(wǎng),公司注重人才、技術(shù)和管理,匯聚了一批優(yōu)秀的互聯(lián)網(wǎng)技術(shù)人才,對客戶都以感恩的心態(tài)奉獻自己的專業(yè)和所長。
MySQL
MySQL是一種開源關(guān)系型數(shù)據(jù)庫,它是Java應用程序最常用的數(shù)據(jù)庫之一。MySQL是一種關(guān)系型數(shù)據(jù)庫,也就是說,它通過相互關(guān)聯(lián)的表來組織數(shù)據(jù)。MySQL可運行在各種各樣的操作系統(tǒng)上,包括Windows、Mac和Linux等。此外,MySQL提供了一個開發(fā)者友好的命令行界面,并且適合于處理大量數(shù)據(jù)。
PostgreSQL
PostgreSQL是一款高度可擴展的關(guān)系型數(shù)據(jù)庫系統(tǒng),它是完全開源的,可以在任何操作系統(tǒng)上運行。PostgreSQL可以處理大量數(shù)據(jù),并提供了很多高級特性,比如復雜的查詢以及自定義函數(shù)。此外,由于PostgreSQL是一個完全開源的數(shù)據(jù)庫,它能夠自由地被Java程序員用于商業(yè)應用開發(fā)。
Oracle
Oracle是一種功能強大的關(guān)系型數(shù)據(jù)庫,它適用于大型企業(yè)級Java應用程序的開發(fā)。Oracle的依賴性管理和資源調(diào)度功能可以大大提高Java應用程序的性能,并為應用程序管理員提供簡單、快速的管理工具。與其他商業(yè)數(shù)據(jù)庫相比,Oracle的可擴展性和可定制性更強,因此更適用于大型企業(yè)級應用程序的開發(fā)。
MongoDB
MongoDB是一種基于文檔的非關(guān)系型數(shù)據(jù)庫,也就是說,它不使用預定義的表和列格式。MongoDB啟用了更簡化和靈活的數(shù)據(jù)管理方式,使Java程序員能夠更輕松地處理數(shù)據(jù)。MongoDB可以通過多種方法訪問,比如JavaScript shell或Java驅(qū)動器API,這使得Java程序員能夠像使用關(guān)系型數(shù)據(jù)庫一樣使用MongoDB。
Cassandra
Cassandra是另一種基于列的非關(guān)系型數(shù)據(jù)庫,適用于處理大量、半結(jié)構(gòu)化的數(shù)據(jù)。Cassandra采用完全分布式架構(gòu),它可以在多個節(jié)點上托管數(shù)據(jù),具有高度的可擴展性,因此適用于高流量的Web應用程序和分布式系統(tǒng)。Java程序員可以使用它來存儲、訪問、查詢非結(jié)構(gòu)化數(shù)據(jù),它提供了一個易于使用的Java API。
Java程序員必備技能之一就是熟練使用各種類型的數(shù)據(jù)庫。MySQL和PostgreSQL是Java程序員最常用的關(guān)系型數(shù)據(jù)庫,Oracle是適用于大型企業(yè)級應用程序的數(shù)據(jù)庫,MongoDB和Cassandra是最常用的非關(guān)系型數(shù)據(jù)庫。選擇適合你的數(shù)據(jù)庫并熟練掌握它將極大地提高你開發(fā)Java應用程序的效率和功能。
成都網(wǎng)站建設(shè)公司-創(chuàng)新互聯(lián),建站經(jīng)驗豐富以策略為先導10多年以來專注數(shù)字化網(wǎng)站建設(shè),提供企業(yè)網(wǎng)站建設(shè),高端網(wǎng)站設(shè)計,響應式網(wǎng)站制作,設(shè)計師量身打造品牌風格,熱線:028-86922220Java開發(fā)常用的幾個數(shù)據(jù)庫連接池
數(shù)據(jù)庫連接池的好處是不言而喻的,現(xiàn)在大部分的application
server都提供自己的數(shù)據(jù)庫連接池方案,此時,只要按照application server的文檔說明,正確配置,即可在應用中享受到數(shù)據(jù)庫連接池的好處。
但是,有些時候,我們的應用是個獨立的java
application,并不是普通的WEB/J2EE應用,而且是單獨運行的,不要什么application
server的配合,這種情況下,我們就需要建立自己的數(shù)據(jù)庫連接池方案了。
1、 DBCP
DBCP是Apache的一個開源項目:
commons.dbcp
DBCP依賴Apache的另外2個開源項目
commons.collections和commons.pool
dbcp包,目前版本是1.2.1:
pool包,目前版本是1.3:
,
common-collections包:
下載這些包并將這些包的路徑添加到classpath中就可以使用dbcp做為項目中的數(shù)據(jù)庫連接池使用了。
在建立我們自己的數(shù)據(jù)庫連接池時,可以使用xml文件來傳入需要的參數(shù),這里只使用hard
code的方式來簡單介紹,所有需要我們自己寫的代碼很少,只要建立一個文件如下:
import
org.apache.commons.dbcp.BasicDataSource;
import
org.apache.commons.dbcp.BasicDataSourceFactory;
import
java.sql.SQLException;
import java.sql.Connection;
import
java.util.Properties;
public class ConnectionSource {
private static BasicDataSource dataSource =
null;
public ConnectionSource() {
}
public static void init() {
if (dataSource != null) {
try
{
dataSource.close();
} catch (Exception e)
{
}
dataSource = null;
}
try {
Properties p = new
Properties();
p.setProperty(“driverClassName”,
“oracle.jdbc.driver.OracleDriver”);
p.setProperty(“url”,
“jdbc:oracle:thin:@192.168.0.1:1521:testDB”);
p.setProperty(“password”, “scott”);
p.setProperty(“username”,
“tiger”);
p.setProperty(“maxActive”, “30”);
p.setProperty(“maxIdle”, “10”);
p.setProperty(“maxWait”,
“1000”);
p.setProperty(“removeAbandoned”,
“false”);
p.setProperty(“removeAbandonedTimeout”,
“120”);
p.setProperty(“testOnBorrow”, “true”);
p.setProperty(“l(fā)ogAbandoned”, “true”);
dataSource = (BasicDataSource)
BasicDataSourceFactory.createDataSource(p);
} catch (Exception e) {
}
}
public static synchronized Connection
getConnection() throws SQLException {
if (dataSource == null) {
init();
}
Connection conn = null;
if (dataSource != null) {
conn = dataSource.getConnection();
}
return conn;
}
}
接下來,在我們的應用中,只要簡單地使用ConnectionSource.getConnection()就可以取得連接池中的數(shù)據(jù)庫連接,享受數(shù)據(jù)庫連接帶給我們的好處了。當我們使用完取得的數(shù)據(jù)庫連接后,只要簡單地使用connection.close()就可把此連接返回到連接池中,至于為什么不是直接關(guān)閉此連接,而是返回給連接池,這是因為dbcp使用委派模型來實現(xiàn)Connection接口了。
在使用Properties來創(chuàng)建BasicDataSource時,有很多參數(shù)可以設(shè)置,比較重要的還有:
testOnBorrow、testOnReturn、testWhileIdle,他們的意思是當是取得連接、返回連接或連接空閑時是否進行有效性驗證(即是否還和數(shù)據(jù)庫連通的),默認都為false。所以當數(shù)據(jù)庫連接因為某種原因斷掉后,再從連接池中取得的連接,實際上可能是無效的連接了,所以,為了確保取得的連接是有效的,
可以把把這些屬性設(shè)為true。當進行校驗時,需要另一個參數(shù):validationQuery,對oracle來說,可以是:SELECT COUNT(*) FROM
DUAL,實際上就是個簡單的SQL語句,驗證時,就是把這個SQL語句在數(shù)據(jù)庫上跑一下而已,如果連接正常的,當然就有結(jié)果返回了。
還有2個參數(shù):timeBetweenEvictionRunsMillis 和
minEvictableIdleTimeMillis,
他們兩個配合,可以持續(xù)更新連接池中的連接對象,當timeBetweenEvictionRunsMillis
大于0時,每過timeBetweenEvictionRunsMillis
時間,就會啟動一個線程,校驗連接池中閑置時間超過minEvictableIdleTimeMillis的連接對象。
還有其他的一些參數(shù),可以參考源代碼。
2、
C0:
C0是一個開放源代碼的JDBC連接池,CO
連接池是一個優(yōu)秀的連接池,推薦使用。CO實現(xiàn)了JDBC3.0規(guī)范的部分功能,因而性能更加突出,包括了實現(xiàn)jdbc3和jdbc2擴展規(guī)范說明的Connection 和Statement 池的DataSources 對象。
下載地址:
package
com.systex.utils.web;
import java.beans.PropertyVetoException;
import
java.sql.Connection;
import java.sql.SQLException;
import
javax.sql.DataSource;
import
com.mchange.v2.c3p0.ComboPooledDataSource;
public class CODataSource {
private static
ComboPooledDataSource dataSource = null;
private static final String driver
= “com.mysql.jdbc.Driver”;
private static final String url =
“jdbc:
private static final String userName =
“root”;
private static final String password = “root”;
public static DataSource getDataSource() {
if
(dataSource == null) {
dataSource = new ComboPooledDataSource();
try
{
dataSource.setDriverClass(driver);
} catch (PropertyVetoException
e) {
System.out.println(“DataSource Load Driver
Exception!!”);
e.printStackTrace();
}
dataSource.setJdbcUrl(url);
dataSource.setUser(userName);
dataSource.setPassword(password);
//
設(shè)置連接池更大連接容量
dataSource.setMaxPoolSize(20);
//
設(shè)置連接池最小連接容量
dataSource.setMinPoolSize(2);
//
設(shè)置連接池更大statements對象容量
dataSource.setMaxStatements(100);
}
return
dataSource;
}
public static Connection getConnection() throws
SQLException {
return
CODataSource.getDataSource().getConnection();
}
}
3、 Proxool
這是一個Java SQL
Driver驅(qū)動程序,提供了對你選擇的其它類型的驅(qū)動程序的連接池封裝??梢苑浅:唵蔚囊浦驳浆F(xiàn)存的代碼中。完全可配置??焖伲墒?,健壯??梢酝该鞯貫槟悻F(xiàn)存的JDBC驅(qū)動程序增加連接池功能。
官方網(wǎng)站:
下載地址:
download.html
DateSource
關(guān)于java 常用的數(shù)據(jù)庫的介紹到此就結(jié)束了,不知道你從中找到你需要的信息了嗎 ?如果你還想了解更多這方面的信息,記得收藏關(guān)注本站。
創(chuàng)新互聯(lián)是成都專業(yè)網(wǎng)站建設(shè)、網(wǎng)站制作、網(wǎng)頁設(shè)計、SEO優(yōu)化、手機網(wǎng)站、小程序開發(fā)、APP開發(fā)公司等,多年經(jīng)驗沉淀,立志成為成都網(wǎng)站建設(shè)第一品牌!
文章標題:Java程序員必備技能:常用數(shù)據(jù)庫一覽!(java常用的數(shù)據(jù)庫)
網(wǎng)站地址:http://www.dlmjj.cn/article/dhspjhc.html


咨詢
建站咨詢
