日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

深入理解r2dbc在mysql中的使用

瀏覽:180日期:2023-10-05 15:14:39
簡(jiǎn)介

mysql應(yīng)該是我們?cè)谌粘9ぷ髦惺褂玫降囊粋€(gè)非常普遍的數(shù)據(jù)庫(kù),雖然mysql現(xiàn)在是oracle公司的,但是它是開源的,市場(chǎng)占有率還是非常高的。

今天我們將會(huì)介紹r2dbc在mysql中的使用。

r2dbc-mysql的maven依賴

要想使用r2dbc-mysql,我們需要添加如下的maven依賴:

<dependency> <groupId>dev.miku</groupId> <artifactId>r2dbc-mysql</artifactId> <version>0.8.2.RELEASE</version></dependency>

當(dāng)然,如果你想使用snapshot版本的話,可以這樣:

<dependency> <groupId>dev.miku</groupId> <artifactId>r2dbc-mysql</artifactId> <version>${r2dbc-mysql.version}.BUILD-SNAPSHOT</version></dependency><repository> <id>sonatype-snapshots</id> <name>SonaType Snapshots</name> <url>https://oss.sonatype.org/content/repositories/snapshots</url> <snapshots> <enabled>true</enabled> </snapshots></repository>創(chuàng)建connectionFactory

創(chuàng)建connectionFactory的代碼實(shí)際上使用的r2dbc的標(biāo)準(zhǔn)接口,所以和之前講到的h2的創(chuàng)建代碼基本上是一樣的:

// Notice: the query string must be URL encodedConnectionFactory connectionFactory = ConnectionFactories.get( 'r2dbcs:mysql://root:database-password-in-here@127.0.0.1:3306/r2dbc?' + 'zeroDate=use_round&' + 'sslMode=verify_identity&' + 'useServerPrepareStatement=true&' + 'tlsVersion=TLSv1.3%2CTLSv1.2%2CTLSv1.1&' + 'sslCa=%2Fpath%2Fto%2Fmysql%2Fca.pem&' + 'sslKey=%2Fpath%2Fto%2Fmysql%2Fclient-key.pem&' + 'sslCert=%2Fpath%2Fto%2Fmysql%2Fclient-cert.pem&' + 'sslKeyPassword=key-pem-password-in-here')// Creating a Mono using Project ReactorMono<Connection> connectionMono = Mono.from(connectionFactory.create());

不同的是ConnectionFactories傳入的參數(shù)不同。

我們也支持unix domain socket的格式:

// Minimum configuration for unix domain socketConnectionFactory connectionFactory = ConnectionFactories.get('r2dbc:mysql://root@unix?unixSocket=%2Fpath%2Fto%2Fmysql.sock')Mono<Connection> connectionMono = Mono.from(connectionFactory.create());

同樣的,我們也支持從ConnectionFactoryOptions中創(chuàng)建ConnectionFactory:

ConnectionFactoryOptions options = ConnectionFactoryOptions.builder() .option(DRIVER, 'mysql') .option(HOST, '127.0.0.1') .option(USER, 'root') .option(PORT, 3306) // optional, default 3306 .option(PASSWORD, 'database-password-in-here') // optional, default null, null means has no password .option(DATABASE, 'r2dbc') // optional, default null, null means not specifying the database .option(CONNECT_TIMEOUT, Duration.ofSeconds(3)) // optional, default null, null means no timeout .option(SSL, true) // optional, default sslMode is 'preferred', it will be ignore if sslMode is set .option(Option.valueOf('sslMode'), 'verify_identity') // optional, default 'preferred' .option(Option.valueOf('sslCa'), '/path/to/mysql/ca.pem') // required when sslMode is verify_ca or verify_identity, default null, null means has no server CA cert .option(Option.valueOf('sslCert'), '/path/to/mysql/client-cert.pem') // optional, default null, null means has no client cert .option(Option.valueOf('sslKey'), '/path/to/mysql/client-key.pem') // optional, default null, null means has no client key .option(Option.valueOf('sslKeyPassword'), 'key-pem-password-in-here') // optional, default null, null means has no password for client key (i.e. 'sslKey') .option(Option.valueOf('tlsVersion'), 'TLSv1.3,TLSv1.2,TLSv1.1') // optional, default is auto-selected by the server .option(Option.valueOf('sslHostnameVerifier'), 'com.example.demo.MyVerifier') // optional, default is null, null means use standard verifier .option(Option.valueOf('sslContextBuilderCustomizer'), 'com.example.demo.MyCustomizer') // optional, default is no-op customizer .option(Option.valueOf('zeroDate'), 'use_null') // optional, default 'use_null' .option(Option.valueOf('useServerPrepareStatement'), true) // optional, default false .option(Option.valueOf('tcpKeepAlive'), true) // optional, default false .option(Option.valueOf('tcpNoDelay'), true) // optional, default false .option(Option.valueOf('autodetectExtensions'), false) // optional, default false .build();ConnectionFactory connectionFactory = ConnectionFactories.get(options);// Creating a Mono using Project ReactorMono<Connection> connectionMono = Mono.from(connectionFactory.create());

或者下面的unix domain socket格式:

// Minimum configuration for unix domain socketConnectionFactoryOptions options = ConnectionFactoryOptions.builder() .option(DRIVER, 'mysql') .option(Option.valueOf('unixSocket'), '/path/to/mysql.sock') .option(USER, 'root') .build();ConnectionFactory connectionFactory = ConnectionFactories.get(options);Mono<Connection> connectionMono = Mono.from(connectionFactory.create());使用MySqlConnectionFactory創(chuàng)建connection

上面的例子中,我們使用的是通用的r2dbc api來(lái)創(chuàng)建connection,同樣的,我們也可以使用特有的MySqlConnectionFactory來(lái)創(chuàng)建connection:

MySqlConnectionConfiguration configuration = MySqlConnectionConfiguration.builder() .host('127.0.0.1') .user('root') .port(3306) // optional, default 3306 .password('database-password-in-here') // optional, default null, null means has no password .database('r2dbc') // optional, default null, null means not specifying the database .serverZoneId(ZoneId.of('Continent/City')) // optional, default null, null means query server time zone when connection init .connectTimeout(Duration.ofSeconds(3)) // optional, default null, null means no timeout .sslMode(SslMode.VERIFY_IDENTITY) // optional, default SslMode.PREFERRED .sslCa('/path/to/mysql/ca.pem') // required when sslMode is VERIFY_CA or VERIFY_IDENTITY, default null, null means has no server CA cert .sslCert('/path/to/mysql/client-cert.pem') // optional, default has no client SSL certificate .sslKey('/path/to/mysql/client-key.pem') // optional, default has no client SSL key .sslKeyPassword('key-pem-password-in-here') // optional, default has no client SSL key password .tlsVersion(TlsVersions.TLS1_3, TlsVersions.TLS1_2, TlsVersions.TLS1_1) // optional, default is auto-selected by the server .sslHostnameVerifier(MyVerifier.INSTANCE) // optional, default is null, null means use standard verifier .sslContextBuilderCustomizer(MyCustomizer.INSTANCE) // optional, default is no-op customizer .zeroDateOption(ZeroDateOption.USE_NULL) // optional, default ZeroDateOption.USE_NULL .useServerPrepareStatement() // Use server-preparing statements, default use client-preparing statements .tcpKeepAlive(true) // optional, controls TCP Keep Alive, default is false .tcpNoDelay(true) // optional, controls TCP No Delay, default is false .autodetectExtensions(false) // optional, controls extension auto-detect, default is true .extendWith(MyExtension.INSTANCE) // optional, manual extend an extension into extensions, default using auto-detect .build();ConnectionFactory connectionFactory = MySqlConnectionFactory.from(configuration);// Creating a Mono using Project ReactorMono<Connection> connectionMono = Mono.from(connectionFactory.create());

或者下面的unix domain socket方式:

// Minimum configuration for unix domain socketMySqlConnectionConfiguration configuration = MySqlConnectionConfiguration.builder() .unixSocket('/path/to/mysql.sock') .user('root') .build();ConnectionFactory connectionFactory = MySqlConnectionFactory.from(configuration);Mono<Connection> connectionMono = Mono.from(connectionFactory.create());執(zhí)行statement

首先看一個(gè)簡(jiǎn)單的不帶參數(shù)的statement:

connection.createStatement('INSERT INTO `person` (`first_name`, `last_name`) VALUES (’who’, ’how’)') .execute(); // return a Publisher include one Result

然后看一個(gè)帶參數(shù)的statement:

connection.createStatement('INSERT INTO `person` (`birth`, `nickname`, `show_name`) VALUES (?, ?name, ?name)') .bind(0, LocalDateTime.of(2019, 6, 25, 12, 12, 12)) .bind('name', 'Some one') // Not one-to-one binding, call twice of native index-bindings, or call once of name-bindings. .add() .bind(0, LocalDateTime.of(2009, 6, 25, 12, 12, 12)) .bind(1, 'My Nickname') .bind(2, 'Naming show') .returnGeneratedValues('generated_id') .execute(); // return a Publisher include two Results.

注意,如果參數(shù)是null的話,可以使用bindNull來(lái)進(jìn)行null值的綁定。

接下來(lái)我們看一個(gè)批量執(zhí)行的操作:

connection.createBatch() .add('INSERT INTO `person` (`first_name`, `last_name`) VALUES (’who’, ’how’)') .add('UPDATE `earth` SET `count` = `count` + 1 WHERE `id` = ’human’') .execute(); // return a Publisher include two Results.執(zhí)行事務(wù)

我們看一個(gè)執(zhí)行事務(wù)的例子:

connection.beginTransaction() .then(Mono.from(connection.createStatement('INSERT INTO `person` (`first_name`, `last_name`) VALUES (’who’, ’how’)').execute())) .flatMap(Result::getRowsUpdated) .thenMany(connection.createStatement('INSERT INTO `person` (`birth`, `nickname`, `show_name`) VALUES (?, ?name, ?name)') .bind(0, LocalDateTime.of(2019, 6, 25, 12, 12, 12)) .bind('name', 'Some one') .add() .bind(0, LocalDateTime.of(2009, 6, 25, 12, 12, 12)) .bind(1, 'My Nickname') .bind(2, 'Naming show') .returnGeneratedValues('generated_id') .execute()) .flatMap(Result::getRowsUpdated) .then(connection.commitTransaction());使用線程池

為了提升數(shù)據(jù)庫(kù)的執(zhí)行效率,減少建立連接的開銷,一般數(shù)據(jù)庫(kù)連接都會(huì)有連接池的概念,同樣的r2dbc也有一個(gè)叫做r2dbc-pool的連接池。

r2dbc-pool的依賴:

<dependency> <groupId>io.r2dbc</groupId> <artifactId>r2dbc-pool</artifactId> <version>${version}</version></dependency>

如果你想使用snapshot版本,也可以這樣指定:

<dependency> <groupId>io.r2dbc</groupId> <artifactId>r2dbc-pool</artifactId> <version>${version}.BUILD-SNAPSHOT</version></dependency><repository> <id>spring-libs-snapshot</id> <name>Spring Snapshot Repository</name> <url>https://repo.spring.io/libs-snapshot</url></repository>

看一下怎么指定數(shù)據(jù)庫(kù)連接池:

ConnectionFactory connectionFactory = ConnectionFactories.get('r2dbc:pool:<my-driver>://<host>:<port>/<database>[?maxIdleTime=PT60S[&…]');Publisher<? extends Connection> connectionPublisher = connectionFactory.create();

可以看到,我們只需要在連接URL上面添加pool這個(gè)driver即可。

同樣的,我們也可以通過(guò)ConnectionFactoryOptions來(lái)創(chuàng)建:

ConnectionFactory connectionFactory = ConnectionFactories.get(ConnectionFactoryOptions.builder() .option(DRIVER, 'pool') .option(PROTOCOL, 'postgresql') // driver identifier, PROTOCOL is delegated as DRIVER by the pool. .option(HOST, '…') .option(PORT, '…') .option(USER, '…') .option(PASSWORD, '…') .option(DATABASE, '…') .build());Publisher<? extends Connection> connectionPublisher = connectionFactory.create();// Alternative: Creating a Mono using Project ReactorMono<Connection> connectionMono = Mono.from(connectionFactory.create());

最后, 你也可以直接通過(guò)創(chuàng)建ConnectionPoolConfiguration來(lái)使用線程池:

ConnectionFactory connectionFactory = …;ConnectionPoolConfiguration configuration = ConnectionPoolConfiguration.builder(connectionFactory) .maxIdleTime(Duration.ofMillis(1000)) .maxSize(20) .build();ConnectionPool pool = new ConnectionPool(configuration); Mono<Connection> connectionMono = pool.create();// laterConnection connection = …;Mono<Void> release = connection.close(); // released the connection back to the pool// application shutdownpool.dispose();

到此這篇關(guān)于深入理解r2dbc在mysql中的使用的文章就介紹到這了,更多相關(guān)mysql r2dbc 內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: MySQL 數(shù)據(jù)庫(kù)
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品一区2区3区| 少妇精品久久久一区二区| 国产精品99在线观看| 色婷婷成人网| 亚洲黄色中文字幕| 欧美在线网站| 日本国产精品| 精品国产aⅴ| 伊人久久一区| 综合一区在线| 国产日韩专区| 久久蜜桃精品| 美女少妇全过程你懂的久久| a国产在线视频| 一区二区三区四区日韩| 伊人久久亚洲| 天堂va蜜桃一区二区三区| 国产一区二区三区久久| 精品三区视频| 欧美日韩一区二区三区四区在线观看| 日韩av一区二区在线影视| 中文字幕av一区二区三区人| 婷婷亚洲综合| 国产在线欧美| 免费污视频在线一区| 美女福利一区二区三区| 久久久久久久久久久妇女 | 激情国产在线| 韩日一区二区| 日本不卡的三区四区五区| 蜜桃一区二区三区| 正在播放日韩精品| 欧美日韩国产在线一区| 国产精品黑丝在线播放| 久久精品国产68国产精品亚洲| 蜜臀久久99精品久久久久宅男 | 日本免费一区二区三区四区| 欧美激情麻豆| 久久精品国产在热久久| 国产精选一区| 日本一区二区三区中文字幕| 香蕉精品999视频一区二区| 久久精品中文| 欧美福利在线| 久久香蕉精品| 日本伊人久久| 久久亚洲图片| 狠狠久久婷婷| 国产亚洲综合精品| 爽好多水快深点欧美视频| 宅男噜噜噜66国产日韩在线观看| av不卡免费看| 免费在线观看日韩欧美| 日日夜夜免费精品视频| 国产精品一区二区精品 | 国产模特精品视频久久久久| 今天的高清视频免费播放成人| 国产精品91一区二区三区| 岛国av在线网站| 肉色欧美久久久久久久免费看| 伊人久久高清| 丝袜美腿一区二区三区| 日韩精品免费视频人成| 精品久久久网| 在线国产一区| 欧美日韩网址| 国产欧美激情| 韩日一区二区三区| 日日夜夜免费精品| 国产成人久久精品麻豆二区| 欧美天堂亚洲电影院在线观看| 四虎国产精品免费久久| 精品午夜av| 黑丝美女一区二区| 日韩欧美中文字幕一区二区三区| 91精品国产自产观看在线| 久久精品系列| 亚洲资源网站| 天堂资源在线亚洲| 国产精品香蕉| 蜜臀久久99精品久久久久宅男| 亚洲深夜视频| 日韩超碰人人爽人人做人人添| 国产在线不卡一区二区三区 | 国产精品天天看天天狠| 免费精品视频| 久久精品国产成人一区二区三区| 99在线精品免费视频九九视| 老司机精品在线| 亚洲伊人精品酒店| 在线成人直播| 日韩在线综合| 国产午夜久久av| 日本在线视频一区二区| 爽爽淫人综合网网站| 夜夜嗨网站十八久久| 欧美久久精品一级c片| 91综合视频| 亚洲精品成人图区| 欧美韩一区二区| 国产精品观看| 久久精品亚洲一区二区| 亚洲美洲欧洲综合国产一区| 三级在线看中文字幕完整版| 麻豆久久久久久| 欧美日韩黄网站| 日本一区福利在线| 日本成人在线视频网站| 日韩久久99| 视频一区日韩精品| 亚洲一区二区免费看| 蜜桃视频欧美| 激情91久久| 香蕉久久一区| 欧美有码在线| 激情视频网站在线播放色| 99精品小视频| 成人日韩精品| 免费在线观看视频一区| 日韩成人av影视| 国产精品白丝久久av网站| 精品免费视频| 午夜精品成人av| 精品一区在线| 国产毛片一区二区三区| 成人免费网站www网站高清| 欧美亚洲精品在线| 亚洲视频国产精品| 免费看av不卡| 中文字幕一区二区三区日韩精品| 免费看欧美美女黄的网站| 国产日韩在线观看视频| 久久一区国产| 欧美影院三区| 国产欧美自拍| 婷婷亚洲五月| 国产精品探花在线观看| 波多野结衣一区| 国产精品一二| 欧美成人日韩| 久久久久观看| 亚洲一区免费| 美腿丝袜亚洲一区| 喷白浆一区二区| 精品久久福利| 日韩欧美久久| 三上悠亚国产精品一区二区三区| 日韩精品a在线观看91| 亚欧成人精品| 国产精品久久国产愉拍| 日韩精品第一区| 综合激情在线| 国产成人精品亚洲日本在线观看| 日日摸夜夜添夜夜添国产精品| 亚洲黄色中文字幕| 91精品国产一区二区在线观看| 91九色精品| 精品国产免费人成网站| 日本不卡视频在线| 国精品一区二区| 69堂免费精品视频在线播放| 欧美~级网站不卡| 麻豆国产精品| 亚洲精品九九| 久久精品高清| 精品国产三区在线| 日韩国产91| 伊人久久亚洲热| 在线视频日韩| 日韩一区二区三区精品视频第3页| 日韩欧美美女在线观看| 成人在线超碰| 国产精品女主播一区二区三区| 亚洲精品福利| 国产精品最新| 国产精品啊v在线| 色天使综合视频| 色偷偷色偷偷色偷偷在线视频| 午夜在线视频观看日韩17c| 欧美激情视频一区二区三区免费| 黄色不卡一区| 亚洲午夜天堂| 亚洲尤物在线| 久久三级毛片| 日韩中文字幕| 国精品一区二区| 老司机精品在线| 日韩精品亚洲专区| 樱桃成人精品视频在线播放| 麻豆精品av| 成人在线视频中文字幕| 亚洲天堂av资源在线观看| 极品av在线| 国产日韩亚洲| 99视频一区| 99pao成人国产永久免费视频| 亚洲精品**中文毛片| 涩涩涩久久久成人精品| 日韩中文在线播放| 精品一区二区三区免费看|