前提・実現したいこと
eclipse内のDBviewer(DBはMySQL)を使用して作成したMySQLデータを、
JDBCでjavaアプリケーションとリンク及び、以降読み書きする方法を検索しつつ試みていたのですが、
あと一歩?のところで下記のエラーメッセージが出てきてしまい手詰まり状態となってしまいました。
該当コード欄に、eclipse(.javaファイル)とsqlに入力した2つのコードを記載させて頂きます。
発生している問題・エラーメッセージ
エラーメッセージ
java.sql.SQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '' at line 1
at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:120)
at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:97)
at com.mysql.cj.jdbc.exceptions.SQLExceptionsMapping.translateException(SQLExceptionsMapping.java:122)
at com.mysql.cj.jdbc.ClientPreparedStatement.executeInternal(ClientPreparedStatement.java:953)
at com.mysql.cj.jdbc.ClientPreparedStatement.executeQuery(ClientPreparedStatement.java:1003)
at Fistr.main(Fistr.java:51)
該当のソースコード
ソースコード
「eclipse(.javaファイル)」
↓↓
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
public class Fistr {
private static String COMMA = ",";
public static void main(String[] args) {
String driverName = "com.mysql.cj.jdbc.Driver";
String jdbcUrl = "jdbc:mysql://localhost:3306?characterEncoding=UTF-8&serverTimezone=JST";
String userId = "root";
String userPass = "tatsu7729";
try{
Class.forName(driverName);
}catch(ClassNotFoundException e) {
e.printStackTrace();
}
Connection con = null;
PreparedStatement ps = null;
ResultSet rs = null;
try {
con = DriverManager.getConnection(jdbcUrl,userId,userPass);
StringBuffer buf = new StringBuffer();
buf.append("SELECT ");
buf.append("id , ");
buf.append("name , ");
buf.append("gender , ");
buf.append("age , ");
ps = con.prepareStatement(buf.toString());
rs = ps.executeQuery();
while(rs.next()) {
StringBuffer rsbuf = new StringBuffer();
rsbuf.append(rs.getString("id"));
rsbuf.append(COMMA);
rsbuf.append(rs.getString("name"));
rsbuf.append(COMMA);
rsbuf.append(rs.getString("gender"));
rsbuf.append(COMMA);
rsbuf.append(rs.getString("age"));
rsbuf.append(COMMA);
System.out.println(rsbuf.toString());
}
}catch(SQLException e){
e.printStackTrace();
}finally{
if (rs != null) {
try {
rs.close();
}catch(SQLException e){
e.printStackTrace();
}
if (ps != null) {
try {
rs.close();
}catch(SQLException e){
e.printStackTrace();
}
if (con != null) {
try {
rs.close();
}catch(SQLException e){
e.printStackTrace();
}
}
}
}
}
}
}
「MySQL」
↓↓
⓵ CREATE DATABASE first;
⓶ USE first
⓷ CREATE TABLE people(
id int,
name varchar(32),
gender varchar(7),
age int
);
SQLではここまで入力しており、SQL上では正常にデータが作成され、表示されております。
試したこと
ネットにて様々な解決策を検索してみましたがわかりませんでした。
コードが読みづらくて申し訳ございませんが、何卒宜しくお願い致します。
補足情報(FW/ツールのバージョンなど)
・eclipse
・MySQL 8.0.17
・DBviewer
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2019/09/19 05:25