婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 深入理解r2dbc在mysql中的使用

深入理解r2dbc在mysql中的使用

熱門標簽:外呼系統(tǒng)打電話上限是多少 百應電話機器人優(yōu)勢 怎樣在地圖標注銷售區(qū)域 地圖標注費用是多少 啥是企業(yè)400電話辦理 電話外呼系統(tǒng)改號 武漢網(wǎng)絡外呼系統(tǒng)服務商 曲靖移動外呼系統(tǒng)公司 南昌三維地圖標注

簡介

mysql應該是我們在日常工作中使用到的一個非常普遍的數(shù)據(jù)庫,雖然mysql現(xiàn)在是oracle公司的,但是它是開源的,市場占有率還是非常高的。

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

r2dbc-mysql的maven依賴

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

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

當然,如果你想使用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的代碼實際上使用的r2dbc的標準接口,所以和之前講到的h2的創(chuàng)建代碼基本上是一樣的:

// Notice: the query string must be URL encoded
ConnectionFactory 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 Reactor
MonoConnection> connectionMono = Mono.from(connectionFactory.create());

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

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

// Minimum configuration for unix domain socket
ConnectionFactory connectionFactory = ConnectionFactories.get("r2dbc:mysql://root@unix?unixSocket=%2Fpath%2Fto%2Fmysql.sock")

MonoConnection> 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 Reactor
MonoConnection> connectionMono = Mono.from(connectionFactory.create());

或者下面的unix domain socket格式:

// Minimum configuration for unix domain socket
ConnectionFactoryOptions options = ConnectionFactoryOptions.builder()
  .option(DRIVER, "mysql")
  .option(Option.valueOf("unixSocket"), "/path/to/mysql.sock")
  .option(USER, "root")
  .build();
ConnectionFactory connectionFactory = ConnectionFactories.get(options);

MonoConnection> connectionMono = Mono.from(connectionFactory.create());

使用MySqlConnectionFactory創(chuàng)建connection

上面的例子中,我們使用的是通用的r2dbc api來創(chuàng)建connection,同樣的,我們也可以使用特有的MySqlConnectionFactory來創(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 Reactor
MonoConnection> connectionMono = Mono.from(connectionFactory.create());

或者下面的unix domain socket方式:

// Minimum configuration for unix domain socket
MySqlConnectionConfiguration configuration = MySqlConnectionConfiguration.builder()
  .unixSocket("/path/to/mysql.sock")
  .user("root")
  .build();
ConnectionFactory connectionFactory = MySqlConnectionFactory.from(configuration);

MonoConnection> connectionMono = Mono.from(connectionFactory.create());

執(zhí)行statement

首先看一個簡單的不帶參數(shù)的statement:

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

然后看一個帶參數(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來進行null值的綁定。

接下來我們看一個批量執(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í)行事務

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

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ù)庫的執(zhí)行效率,減少建立連接的開銷,一般數(shù)據(jù)庫連接都會有連接池的概念,同樣的r2dbc也有一個叫做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ù)庫連接池:

ConnectionFactory connectionFactory = ConnectionFactories.get("r2dbc:pool:my-driver>://host>:port>/database>[?maxIdleTime=PT60S[…]");

Publisher? extends Connection> connectionPublisher = connectionFactory.create();

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

同樣的,我們也可以通過ConnectionFactoryOptions來創(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 Reactor
MonoConnection> connectionMono = Mono.from(connectionFactory.create());

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

ConnectionFactory connectionFactory = …;

ConnectionPoolConfiguration configuration = ConnectionPoolConfiguration.builder(connectionFactory)
  .maxIdleTime(Duration.ofMillis(1000))
  .maxSize(20)
  .build();

ConnectionPool pool = new ConnectionPool(configuration);
 

MonoConnection> connectionMono = pool.create();

// later

Connection connection = …;
MonoVoid> release = connection.close(); // released the connection back to the pool

// application shutdown
pool.dispose();

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

您可能感興趣的文章:
  • mysql安裝圖解 mysql圖文安裝教程(詳細說明)
  • Mysql字符串截取函數(shù)SUBSTRING的用法說明
  • MySQL創(chuàng)建用戶與授權(quán)方法
  • mysql update語句的用法詳解
  • MySQL 的CASE WHEN 語句使用說明
  • mysql中int、bigint、smallint 和 tinyint的區(qū)別詳細介紹
  • mysql 添加索引 mysql 如何創(chuàng)建索引
  • mySQL中replace的用法

標簽:荊州 資陽 甘南 吉林 錦州 滄州 隨州 黑河

巨人網(wǎng)絡通訊聲明:本文標題《深入理解r2dbc在mysql中的使用》,本文關(guān)鍵詞  深入,理解,r2dbc,在,mysql,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《深入理解r2dbc在mysql中的使用》相關(guān)的同類信息!
  • 本頁收集關(guān)于深入理解r2dbc在mysql中的使用的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美日韩在线综合| 久久成人av少妇免费| 亚洲在线中文字幕| 99久久综合精品| 久久精品男人的天堂| 天天色图综合网| 欧美精品1区2区| 日本成人中文字幕在线视频| 精品日韩欧美在线| 国产.欧美.日韩| 国产日韩视频一区二区三区| 国产成人av电影在线| 国产精品久久久久影院| 91视频精品在这里| 日本成人中文字幕| 国产欧美一区二区精品婷婷 | 日韩欧美国产综合| 极品少妇一区二区三区精品视频| 久久理论电影网| 不卡一区二区三区四区| 亚洲综合在线第一页| 制服丝袜国产精品| 国产激情视频一区二区在线观看| 亚洲精品乱码久久久久久久久| 91精品国产手机| heyzo一本久久综合| 日韩av电影免费观看高清完整版在线观看| 日韩欧美国产精品| av电影在线不卡| 日韩精品免费专区| 中文字幕亚洲综合久久菠萝蜜| 色婷婷精品久久二区二区蜜臀av| 久久国产尿小便嘘嘘尿| 国产精品久久久久久久久搜平片| 欧美精品亚洲二区| 91亚洲精品久久久蜜桃| 日韩av二区在线播放| 一区二区三区四区在线免费观看| 精品国产凹凸成av人网站| 在线观看视频一区二区| 国产不卡在线一区| 蜜乳av一区二区| 一区二区三区高清在线| 国产精品乱子久久久久| 国产日韩欧美麻豆| 欧美白人最猛性xxxxx69交| 91久久国产综合久久| 成人激情黄色小说| 国产老妇另类xxxxx| 美国十次综合导航| 亚洲国产成人91porn| 亚洲综合男人的天堂| 亚洲欧美激情小说另类| 亚洲欧美怡红院| 国产精品久久久久久久蜜臀 | 成人97人人超碰人人99| 国产精品影视在线| 国产一区二区三区在线看麻豆| 日韩成人午夜电影| 五月天激情小说综合| 亚洲制服丝袜一区| 亚洲欧美日韩在线不卡| 亚洲欧美电影一区二区| 亚洲激情五月婷婷| 亚洲综合色噜噜狠狠| 亚洲国产一区二区在线播放| 亚洲一区二区三区自拍| 亚洲自拍都市欧美小说| 亚洲gay无套男同| 日韩国产精品91| 日本成人中文字幕在线视频| 蜜桃视频第一区免费观看| 另类小说欧美激情| 国模套图日韩精品一区二区 | 亚洲欧美日韩电影| 悠悠色在线精品| 亚洲午夜私人影院| 日本中文一区二区三区| 精品一区二区三区在线播放视频| 久久91精品久久久久久秒播| 国产久卡久卡久卡久卡视频精品| 国产自产高清不卡| 99久久久免费精品国产一区二区| 91麻豆产精品久久久久久| 欧洲一区二区三区在线| 4438x成人网最大色成网站| 精品欧美一区二区在线观看 | www日韩大片| 国产精品三级在线观看| 亚洲一区二区三区视频在线播放 | 在线免费观看日本欧美| 欧美卡1卡2卡| 久久精品亚洲国产奇米99| 中文字幕一区二区视频| 天天亚洲美女在线视频| 成人免费看片app下载| 欧美做爰猛烈大尺度电影无法无天| 欧美日本高清视频在线观看| 久久久久国产精品厨房| 亚洲欧洲另类国产综合| 日韩二区三区在线观看| 成人精品视频.| 欧美日本国产一区| 国产日韩精品久久久| 国产片一区二区三区| 午夜久久久久久电影| 国产久卡久卡久卡久卡视频精品| 日本电影亚洲天堂一区| 久久精品视频一区| 日韩avvvv在线播放| 色综合天天在线| 久久久久久久久一| 美女视频免费一区| 日本二三区不卡| 中文子幕无线码一区tr| 激情综合网av| 欧美片在线播放| 1区2区3区精品视频| 国产伦精品一区二区三区免费迷 | 亚洲福利视频三区| 国产一区欧美一区| 777久久久精品| 亚洲电影在线免费观看| 成人激情动漫在线观看| 337p粉嫩大胆噜噜噜噜噜91av| 亚洲午夜免费视频| 欧美亚洲动漫精品| 亚洲精品va在线观看| eeuss鲁片一区二区三区在线看| 精品盗摄一区二区三区| 免费精品视频最新在线| 欧美群妇大交群的观看方式| 亚洲综合一区二区三区| 欧美性色欧美a在线播放| 亚洲三级小视频| 成人精品在线视频观看| 中文字幕电影一区| 国产成人在线电影| 国产日韩欧美一区二区三区综合 | 欧美性猛片aaaaaaa做受| 自拍视频在线观看一区二区| www.66久久| 亚洲免费成人av| 欧美亚洲国产bt| 五月婷婷另类国产| 日韩精品一区二区三区中文不卡 | 亚洲欧美怡红院| 91丨porny丨中文| 亚洲欧美欧美一区二区三区| 99久久国产免费看| 亚洲情趣在线观看| 欧美日韩国产色站一区二区三区| 亚洲1区2区3区4区| 欧美高清视频www夜色资源网| 午夜精品福利一区二区三区av| 欧美一区二区三区播放老司机| 美国一区二区三区在线播放| 久久久久久综合| 99re在线精品| 亚洲成av人在线观看| 日韩欧美自拍偷拍| 精品在线你懂的| 国产日本一区二区| 成人黄色av电影| 亚洲婷婷综合久久一本伊一区| 欧美日韩国产精选| 国产精品 欧美精品| 国产精品久久久久婷婷| 精品视频在线免费| 国产成人午夜视频| 亚洲成人tv网| 337p日本欧洲亚洲大胆精品| 高清成人在线观看| 亚洲免费伊人电影| 在线播放中文一区| 国产精品自拍毛片| 亚洲精品免费电影| 久久午夜免费电影| 欧美性猛交一区二区三区精品 | 久久国产免费看| 国产网站一区二区| 欧美日韩国产一级二级| 国产精品一线二线三线| 一区二区三区免费| 亚洲精品一区二区三区香蕉| 色婷婷久久综合| 狠狠色综合播放一区二区| 综合久久久久久| 国产欧美一区二区在线| 欧美一区二区三区在线电影 | 91丨九色丨蝌蚪富婆spa| 国产精品影音先锋| 精品一区二区三区在线观看国产 | 久久精品国产一区二区三| 亚洲欧美二区三区| 国产三级一区二区三区| 欧美一区二区免费视频| 欧美影院一区二区三区| 不卡一区二区在线| www.欧美.com|