日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
Java程序員必備技能:常用數(shù)據(jù)庫(kù)一覽!(java常用的數(shù)據(jù)庫(kù))

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

創(chuàng)新互聯(lián)秉承實(shí)現(xiàn)全網(wǎng)價(jià)值營(yíng)銷的理念,以專業(yè)定制企業(yè)官網(wǎng),成都做網(wǎng)站、網(wǎng)站設(shè)計(jì),小程序開發(fā),網(wǎng)頁(yè)設(shè)計(jì)制作,成都手機(jī)網(wǎng)站制作,成都全網(wǎng)營(yíng)銷幫助傳統(tǒng)企業(yè)實(shí)現(xiàn)“互聯(lián)網(wǎng)+”轉(zhuǎn)型升級(jí)專業(yè)定制企業(yè)官網(wǎng),公司注重人才、技術(shù)和管理,匯聚了一批優(yōu)秀的互聯(lián)網(wǎng)技術(shù)人才,對(duì)客戶都以感恩的心態(tài)奉獻(xiàn)自己的專業(yè)和所長(zhǎng)。

MySQL

MySQL是一種開源關(guān)系型數(shù)據(jù)庫(kù),它是Java應(yīng)用程序最常用的數(shù)據(jù)庫(kù)之一。MySQL是一種關(guān)系型數(shù)據(jù)庫(kù),也就是說,它通過相互關(guān)聯(lián)的表來組織數(shù)據(jù)。MySQL可運(yùn)行在各種各樣的操作系統(tǒng)上,包括Windows、Mac和Linux等。此外,MySQL提供了一個(gè)開發(fā)者友好的命令行界面,并且適合于處理大量數(shù)據(jù)。

PostgreSQL

PostgreSQL是一款高度可擴(kuò)展的關(guān)系型數(shù)據(jù)庫(kù)系統(tǒng),它是完全開源的,可以在任何操作系統(tǒng)上運(yùn)行。PostgreSQL可以處理大量數(shù)據(jù),并提供了很多高級(jí)特性,比如復(fù)雜的查詢以及自定義函數(shù)。此外,由于PostgreSQL是一個(gè)完全開源的數(shù)據(jù)庫(kù),它能夠自由地被Java程序員用于商業(yè)應(yīng)用開發(fā)。

Oracle

Oracle是一種功能強(qiáng)大的關(guān)系型數(shù)據(jù)庫(kù),它適用于大型企業(yè)級(jí)Java應(yīng)用程序的開發(fā)。Oracle的依賴性管理和資源調(diào)度功能可以大大提高Java應(yīng)用程序的性能,并為應(yīng)用程序管理員提供簡(jiǎn)單、快速的管理工具。與其他商業(yè)數(shù)據(jù)庫(kù)相比,Oracle的可擴(kuò)展性和可定制性更強(qiáng),因此更適用于大型企業(yè)級(jí)應(yīng)用程序的開發(fā)。

MongoDB

MongoDB是一種基于文檔的非關(guān)系型數(shù)據(jù)庫(kù),也就是說,它不使用預(yù)定義的表和列格式。MongoDB啟用了更簡(jiǎn)化和靈活的數(shù)據(jù)管理方式,使Java程序員能夠更輕松地處理數(shù)據(jù)。MongoDB可以通過多種方法訪問,比如JavaScript shell或Java驅(qū)動(dòng)器API,這使得Java程序員能夠像使用關(guān)系型數(shù)據(jù)庫(kù)一樣使用MongoDB。

Cassandra

Cassandra是另一種基于列的非關(guān)系型數(shù)據(jù)庫(kù),適用于處理大量、半結(jié)構(gòu)化的數(shù)據(jù)。Cassandra采用完全分布式架構(gòu),它可以在多個(gè)節(jié)點(diǎn)上托管數(shù)據(jù),具有高度的可擴(kuò)展性,因此適用于高流量的Web應(yīng)用程序和分布式系統(tǒng)。Java程序員可以使用它來存儲(chǔ)、訪問、查詢非結(jié)構(gòu)化數(shù)據(jù),它提供了一個(gè)易于使用的Java API。

Java程序員必備技能之一就是熟練使用各種類型的數(shù)據(jù)庫(kù)。MySQL和PostgreSQL是Java程序員最常用的關(guān)系型數(shù)據(jù)庫(kù),Oracle是適用于大型企業(yè)級(jí)應(yīng)用程序的數(shù)據(jù)庫(kù),MongoDB和Cassandra是最常用的非關(guān)系型數(shù)據(jù)庫(kù)。選擇適合你的數(shù)據(jù)庫(kù)并熟練掌握它將極大地提高你開發(fā)Java應(yīng)用程序的效率和功能。

成都網(wǎng)站建設(shè)公司-創(chuàng)新互聯(lián),建站經(jīng)驗(yàn)豐富以策略為先導(dǎo)10多年以來專注數(shù)字化網(wǎng)站建設(shè),提供企業(yè)網(wǎng)站建設(shè),高端網(wǎng)站設(shè)計(jì),響應(yīng)式網(wǎng)站制作,設(shè)計(jì)師量身打造品牌風(fēng)格,熱線:028-86922220

Java開發(fā)常用的幾個(gè)數(shù)據(jù)庫(kù)連接池

數(shù)據(jù)庫(kù)連接池的好處是不言而喻的,現(xiàn)在大部分的application

server都提供自己的數(shù)據(jù)庫(kù)連接池方案,此時(shí),只要按照application server的文檔說明,正確配置,即可在應(yīng)用中享受到數(shù)據(jù)庫(kù)連接池的好處。

但是,有些時(shí)候,我們的應(yīng)用是個(gè)獨(dú)立的java

application,并不是普通的WEB/J2EE應(yīng)用,而且是單獨(dú)運(yùn)行的,不要什么application

server的配合,這種情況下,我們就需要建立自己的數(shù)據(jù)庫(kù)連接池方案了。

1、 DBCP

DBCP是Apache的一個(gè)開源項(xiàng)目:

commons.dbcp

DBCP依賴Apache的另外2個(gè)開源項(xiàng)目

commons.collections和commons.pool

dbcp包,目前版本是1.2.1:

pool包,目前版本是1.3:

,

common-collections包:

下載這些包并將這些包的路徑添加到classpath中就可以使用dbcp做為項(xiàng)目中的數(shù)據(jù)庫(kù)連接池使用了。

在建立我們自己的數(shù)據(jù)庫(kù)連接池時(shí),可以使用xml文件來傳入需要的參數(shù),這里只使用hard

code的方式來簡(jiǎn)單介紹,所有需要我們自己寫的代碼很少,只要建立一個(gè)文件如下:

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;

}

}

接下來,在我們的應(yīng)用中,只要簡(jiǎn)單地使用ConnectionSource.getConnection()就可以取得連接池中的數(shù)據(jù)庫(kù)連接,享受數(shù)據(jù)庫(kù)連接帶給我們的好處了。當(dāng)我們使用完取得的數(shù)據(jù)庫(kù)連接后,只要簡(jiǎn)單地使用connection.close()就可把此連接返回到連接池中,至于為什么不是直接關(guān)閉此連接,而是返回給連接池,這是因?yàn)閐bcp使用委派模型來實(shí)現(xiàn)Connection接口了。

在使用Properties來創(chuàng)建BasicDataSource時(shí),有很多參數(shù)可以設(shè)置,比較重要的還有:

testOnBorrow、testOnReturn、testWhileIdle,他們的意思是當(dāng)是取得連接、返回連接或連接空閑時(shí)是否進(jìn)行有效性驗(yàn)證(即是否還和數(shù)據(jù)庫(kù)連通的),默認(rèn)都為false。所以當(dāng)數(shù)據(jù)庫(kù)連接因?yàn)槟撤N原因斷掉后,再?gòu)倪B接池中取得的連接,實(shí)際上可能是無效的連接了,所以,為了確保取得的連接是有效的,

可以把把這些屬性設(shè)為true。當(dāng)進(jìn)行校驗(yàn)時(shí),需要另一個(gè)參數(shù):validationQuery,對(duì)oracle來說,可以是:SELECT COUNT(*) FROM

DUAL,實(shí)際上就是個(gè)簡(jiǎn)單的SQL語句,驗(yàn)證時(shí),就是把這個(gè)SQL語句在數(shù)據(jù)庫(kù)上跑一下而已,如果連接正常的,當(dāng)然就有結(jié)果返回了。

還有2個(gè)參數(shù):timeBetweenEvictionRunsMillis 和

minEvictableIdleTimeMillis,

他們兩個(gè)配合,可以持續(xù)更新連接池中的連接對(duì)象,當(dāng)timeBetweenEvictionRunsMillis

大于0時(shí),每過timeBetweenEvictionRunsMillis

時(shí)間,就會(huì)啟動(dòng)一個(gè)線程,校驗(yàn)連接池中閑置時(shí)間超過minEvictableIdleTimeMillis的連接對(duì)象。

還有其他的一些參數(shù),可以參考源代碼。

2、

C0:

C0是一個(gè)開放源代碼的JDBC連接池,CO

連接池是一個(gè)優(yōu)秀的連接池,推薦使用。CO實(shí)現(xiàn)了JDBC3.0規(guī)范的部分功能,因而性能更加突出,包括了實(shí)現(xiàn)jdbc3和jdbc2擴(kuò)展規(guī)范說明的Connection 和Statement 池的DataSources 對(duì)象。

下載地址:

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對(duì)象容量

dataSource.setMaxStatements(100);

}

return

dataSource;

}

public static Connection getConnection() throws

SQLException {

return

CODataSource.getDataSource().getConnection();

}

}

3、 Proxool

這是一個(gè)Java SQL

Driver驅(qū)動(dòng)程序,提供了對(duì)你選擇的其它類型的驅(qū)動(dòng)程序的連接池封裝??梢苑浅:?jiǎn)單的移植到現(xiàn)存的代碼中。完全可配置??焖?,成熟,健壯??梢酝该鞯貫槟悻F(xiàn)存的JDBC驅(qū)動(dòng)程序增加連接池功能。

官方網(wǎng)站:

下載地址:

download.html

DateSource

關(guān)于java 常用的數(shù)據(jù)庫(kù)的介紹到此就結(jié)束了,不知道你從中找到你需要的信息了嗎 ?如果你還想了解更多這方面的信息,記得收藏關(guān)注本站。

創(chuàng)新互聯(lián)是成都專業(yè)網(wǎng)站建設(shè)、網(wǎng)站制作、網(wǎng)頁(yè)設(shè)計(jì)、SEO優(yōu)化、手機(jī)網(wǎng)站、小程序開發(fā)、APP開發(fā)公司等,多年經(jīng)驗(yàn)沉淀,立志成為成都網(wǎng)站建設(shè)第一品牌!


分享名稱:Java程序員必備技能:常用數(shù)據(jù)庫(kù)一覽!(java常用的數(shù)據(jù)庫(kù))
瀏覽地址:http://www.5511xx.com/article/dhspjhc.html