V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX  ›  chaoschick  ›  全部回复第 2 页 / 共 20 页
回复总数  397
1  2  3  4  5  6  7  8  9  10 ... 20  
太浮躁了, 技术需要沉淀
一朝悟道, 必假十年苦修
把公司干倒闭 🐶
144 天前
回复了 hastyfish 创建的主题 问与答 关于 JDBC 连接 Mysql,求一个大佬
这个问题通常是由于 `JdbcRowSet` 和 `DriverManager` 处理 JDBC 驱动的方式有所不同。让我们逐步分析:

### 1. **`Class.forName("com.mysql.cj.jdbc.Driver")` 的作用**
- 这行代码的作用是加载并注册 MySQL 的 JDBC 驱动程序。在大多数现代 JDBC 驱动程序中,这步操作是自动完成的,因为 JDBC 4.0 引入了自动加载驱动的功能,但显式调用 `Class.forName` 可以确保兼容性。

### 2. **`DriverManager.getConnection` 的行为**
- 当使用 `DriverManager.getConnection` 时,`DriverManager` 会根据你提供的 JDBC URL (`jdbc:mysql://localhost:3306/sonoo`) 查找已经注册的驱动程序,并找到合适的驱动来建立连接。因为 `Class.forName` 已经注册了 MySQL 驱动,所以能够正常连接数据库。

### 3. **`JdbcRowSet` 的行为**
- `JdbcRowSet` 是一种 RowSet ,它通过内部的 `Connection` 对象来连接数据库。你在创建 `JdbcRowSet` 时并没有显式地传入 `Connection`,而是通过 `setUrl` 等方法提供连接信息。

- 关键问题在于,`JdbcRowSet` 使用的连接过程可能与 `DriverManager` 不同。特别是当 `JdbcRowSet` 使用 `RowSetProvider` 创建时,内部可能没有找到合适的驱动程序来处理 `jdbc:mysql://localhost:3306/sonoo` 这个 URL 。

### **为什么会出现 `No suitable driver found` 错误**

- 在使用 `DriverManager.getConnection` 时,`DriverManager` 已经注册并正确识别了 MySQL 驱动程序,因此能成功建立连接。
- 然而,在使用 `JdbcRowSet` 时,如果它不能正确加载 MySQL 驱动程序(可能是因为 `RowSetProvider` 的内部实现或者没有正确注册驱动),那么它就会抛出 `java.sql.SQLException: No suitable driver found for jdbc:mysql://localhost:3306/sonoo` 这样的错误。

### **解决方法**

1. **显式加载 JDBC 驱动:**
确保在使用 `JdbcRowSet` 前已经加载并注册了 MySQL 驱动程序:
```java
Class.forName("com.mysql.cj.jdbc.Driver");
```

2. **使用 `JdbcRowSet` 时显式传入连接:**
你可以先创建一个 `Connection` 对象,然后将其传入 `JdbcRowSet` 中使用:
```java
Class.forName("com.mysql.cj.jdbc.Driver");
Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/sonoo","root","root");
JdbcRowSet rowSet = RowSetProvider.newFactory().createJdbcRowSet();
rowSet.setCommand("select * from user420");
rowSet.execute(con); // 使用已有的 Connection 对象
```

这种方式确保 `JdbcRowSet` 使用的连接和 `DriverManager` 创建的连接是相同的。

3. **确保 `RowSetProvider` 支持 MySQL:**
如果你使用的 `RowSetProvider` 实现确实不支持 MySQL ,考虑使用替代的 `RowSet` 实现,或者确保你的环境中已正确配置支持 MySQL 的 `RowSetProvider`。

通过上述方法,可以避免 `JdbcRowSet` 报 `No suitable driver found` 的错误。
144 天前
回复了 jchnxu 创建的主题 程序员 jdbc 是个啥原理啊
Node.js 中有多个库可以用于连接和操作数据库,最常用的包括以下几个:

1. **MySQL**:
- 使用 `mysql` 或 `mysql2` 库来连接 MySQL 数据库。
- 示例:
```javascript
const mysql = require('mysql2');

const connection = mysql.createConnection({
host: 'localhost',
user: 'yourUsername',
password: 'yourPassword',
database: 'yourDatabase'
});

connection.connect(err => {
if (err) {
console.error('Error connecting to the database:', err);
return;
}
console.log('Connected to the MySQL database.');
});

connection.query('SELECT * FROM yourTable', (err, results) => {
if (err) {
console.error('Error executing query:', err);
return;
}
console.log('Query results:', results);
});

connection.end();
```

2. **PostgreSQL**:
- 使用 `pg` 库来连接 PostgreSQL 数据库。
- 示例:
```javascript
const { Client } = require('pg');

const client = new Client({
host: 'localhost',
user: 'yourUsername',
password: 'yourPassword',
database: 'yourDatabase'
});

client.connect(err => {
if (err) {
console.error('Error connecting to the database:', err);
return;
}
console.log('Connected to the PostgreSQL database.');
});

client.query('SELECT * FROM yourTable', (err, res) => {
if (err) {
console.error('Error executing query:', err);
return;
}
console.log('Query results:', res.rows);
});

client.end();
```

3. **SQLite**:
- 使用 `sqlite3` 库来连接 SQLite 数据库。
- 示例:
```javascript
const sqlite3 = require('sqlite3').verbose();

const db = new sqlite3.Database('./yourDatabase.db');

db.serialize(() => {
db.each('SELECT * FROM yourTable', (err, row) => {
if (err) {
console.error('Error executing query:', err);
return;
}
console.log('Row:', row);
});
});

db.close();
```
144 天前
回复了 gomorebug 创建的主题 Java 关于 mybatis 的疑惑
说的很好 但是我用 JDBC 🐶
g++ main.cpp -O3
a.exe

windows 7 (vmware)
Time taken to output the result: 122.007 milliseconds

windows 10 (物理机)
Time taken to output the result: 3.7429 milliseconds

windows server 2019 (内网服务器)
Time taken to output the result: 73.7804 milliseconds
@seanzxx 那多半就是 windows 的终端有问题了 我试过 windows 的 cmd 与 powershell 都有这个问题
@RecursiveG 很快 我已经试过了 重定向到文件 10ms 以内了
#include <iostream>
#include <chrono>
#include <sstream>

int main() {
// Output the result
auto start_time = std::chrono::high_resolution_clock::now();
std::ios::sync_with_stdio(false);
std::cin.tie(NULL);
const size_t bufferSize = 1024 * 1024 * 100;
char *buffer = new char[bufferSize];
std::cout.rdbuf()->pubsetbuf(buffer, bufferSize);

std::ostringstream oss;
for (int i = -1; ++i < 1000; ) {
oss << "Column 1: 1, Column 2: 2, Column 3: 3, Column 4: 4\n";
}
std::cout << oss.str();
auto end_time = std::chrono::high_resolution_clock::now();
std::chrono::duration<double, std::milli> elapsed = end_time - start_time;
std::cout << "Time taken to output the result: " << elapsed.count() << " milliseconds\n";

delete[] buffer;

return 0;
}
我把同样的代码 在 linux 跑了一遍

g++ main.cpp -O3
./a.out

Time taken to output the result: 11.9875 milliseconds
。。。
@leconio 我下载了 jbr17
D:\cpp\demo4\jbrsdk-17.0.9-windows-x64-b1087.7\bin\java Main.java

Time taken to output the result: 124 milliseconds
Time taken to output the result: 124 milliseconds
@chendy
#include <iostream>
#include <chrono>
#include <sstream>

int main() {
// Output the result
auto start_time = std::chrono::high_resolution_clock::now();
std::ios::sync_with_stdio(false);
std::cin.tie(NULL);
const size_t bufferSize = 1024 * 1024 * 100;
char *buffer = new char[bufferSize];
std::cout.rdbuf()->pubsetbuf(buffer, bufferSize);

std::ostringstream oss;
for (int i = -1; ++i < 1000; ) {
oss << "Column 1: 1, Column 2: 2, Column 3: 3, Column 4: 4\n";
}
std::cout << oss.str();
auto end_time = std::chrono::high_resolution_clock::now();
std::chrono::duration<double, std::milli> elapsed = end_time - start_time;
std::cout << "Time taken to output the result: " << elapsed.count() << " milliseconds\n";

delete[] buffer;

return 0;
}

编译 g++ main.cpp -O3
运行 a.exe

Time taken to output the result: 124.007 milliseconds

这是 c++ 写的代码 我已经将 buffer 调大了 但是还是维持在 100ms 左右
@chendy 我也怀疑这个 idea 可能做了什么操作
我使用 c++ 写了一个一样逻辑的代码 然后 g++ main.cpp -O3 && a.exe 测试发现也需要 100ms 左右
所以我怀疑 idea 的控制台
编译 javac Main.java
运行 java Main
@kneo 试了 编译后再执行

Time taken to output the result: 122 milliseconds
Time taken to output the result: 122 milliseconds
@lucasj 我把控制台中的 最上面那一部分的命令完全 copy 后放到 bat 批处理脚本
然后运行
Time taken to output the result: 121 milliseconds
Time taken to output the result: 121 milliseconds
154 天前
回复了 fingerxie 创建的主题 职场话题 最近有些迷茫,不知道该不该继续学习
楼主会什么技术?
可以交流一下 my tg
https://t.me/ccpiwi
https://www.v2ex.com/t/1065578
你这边刚吐槽 原生 iOS 开发 隔壁就发布了一个招聘 🙄
太年轻了
160 天前
回复了 spiderGgl 创建的主题 北京 最惨的程序员( Java 爬虫方向的职业生涯)
@spiderGgl 大部分时候没时间去关心安全方面的事 领导催着快速开发产品 快速抢占市场 所以只关心业务方面的实现
开发某个功能的时候 会先去找有没有现成的 如果有就直接用 所以会导致 某个东西一旦有漏洞 影响的就是一大片区域
比如说最近非常流行的 spingboot 框架 一旦这个框架的某个版本有漏洞 那么影响的区域就会非常广
1  2  3  4  5  6  7  8  9  10 ... 20  
关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5721 人在线   最高记录 6679   ·     Select Language
创意工作者们的社区
World is powered by solitude
VERSION: 3.9.8.5 · 28ms · UTC 02:17 · PVG 10:17 · LAX 18:17 · JFK 21:17
Developed with CodeLauncher
♥ Do have faith in what you're doing.