溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何實現(xiàn)MySQL安裝與idea的連接

發(fā)布時間:2022-01-05 17:26:46 來源:億速云 閱讀:146 作者:小新 欄目:開發(fā)技術(shù)

這篇文章將為大家詳細講解有關(guān)如何實現(xiàn)MySQL安裝與idea的連接,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

MySQL安裝與idea的連接

--編輯my.ini配置文件內(nèi)容(Mysql 8.0以上不需要,直接安裝即可)
[mysql]
# 設置mysql客戶端默認字符集
default-character-set=utf8 
[mysqld]
#設置3306端口
port = 3306 
# 設置mysql的安裝目錄
basedir=E:\MySQL5.7.13\mysql-5.7.13-winx64
# 設置mysql數(shù)據(jù)庫的數(shù)據(jù)的存放目錄
datadir=E:\MySQL5.7.13\mysql-5.7.13-winx64\data
# 允許最大連接數(shù)
max_connections=200
# 服務端使用的字符集默認為8比特編碼的latin1字符集
character-set-server=utf8
# 創(chuàng)建新表時將使用的默認存儲引擎
default-storage-engine=INNODB
# 安裝好后, 免密碼進入mysql
skip-grant-tables

--用管理員身份運行cmd,輸入命令
//安裝mysql
mysqld -install 
//安裝成功后,初始化數(shù)據(jù)文件
mysqld --initialize-insecure --user=mysql
//進入mysql管理界面
mysql -u root-p
//修改密碼
update mysql.user set password=password('新密碼') where user='root';
//mysql8修改密碼
alter user 'root'@'localhost' identified by '密碼'

Mysql與idea進行連接

1.導入數(shù)據(jù)庫驅(qū)動

點擊連接進行下載:(mysql驅(qū)動)

https://github.com/epochong/mysql-connector-java-8.0.16.git

下載后在idea目錄下新建lib目錄,將下載好的驅(qū)動移動到lib目錄下,并右擊點擊添加為庫,再次點擊驅(qū)動文件,若能展開,則驅(qū)動安裝成功。

如何實現(xiàn)MySQL安裝與idea的連接

連接過程若出現(xiàn)驅(qū)動問題,需要注意查看驅(qū)動是否添加為庫,英文版(add as library),查看驅(qū)動版本的問題(下載驅(qū)動需要對應與數(shù)據(jù)庫,例mysql下載mysql驅(qū)動,sql server下載的是sql server驅(qū)動,查看是否在同一包下,有時候不在同一包下會找不到驅(qū)動)。

2.連接數(shù)據(jù)庫(最基本的連接方法)

package jdbc_excise;

import java.sql.*;

public class Jdbc {
    public static void main(String[] args) throws SQLException {
        try {
            Class.forName("com.mysql.jdbc.Driver");

            String url = "jdbc:mysql://localhost:3306/student?useUnicode=true&characterEncoding=utf8&useSSL=false";
            //通用模板:jdbc:數(shù)據(jù)庫名字://地址:端口/實際使用數(shù)據(jù)庫名稱?附加參數(shù)
            String username = "root";
            String password = "123456";

           Connection connection = DriverManager.getConnection(url,username,password);
           Statement statement = connection.createStatement();
            //執(zhí)行sql查詢語句
           String sql = "select * from student";
           ResultSet resultSet = statement.executeQuery(sql);

           while (resultSet.next()){
               System.out.println("Sno="+resultSet.getObject("Sno"));
          }

           resultSet.close();
           statement.close();
           connection.close();

        } catch (ClassNotFoundException e) {
            e.printStackTrace();

        }
    }


}

**附狂神教程中安全連接解決辦法 **

jdbc:mysql://localhost:3306/student?useUnicode=true&characterEncoding=utf8&useSSL=false

若mysql版本高于驅(qū)動版本,則需要將安全連接置為false;置為true會報錯。

封裝工具類連接數(shù)據(jù)庫

編寫配置文件

--新建配置文件:db.properties--

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/student?useUnicode=true&characterEncoding=utf8&useSSL=false
username=root
password=123456

封裝工具類

package connect_jdbc.utils;

import java.io.IOException;
import java.io.InputStream;
import java.sql.*;
import java.util.Properties;

public class JdbcUtils {
    private  static String driver = null;;
    private static String url =null;
    private static String username = null;
    private static  String password = null;

    static {
        try{
            //通過反射得到配置文件中的內(nèi)容
           InputStream in = JdbcUtils.class.getClassLoader().getResourceAsStream("db.properties");
            Properties properties=new Properties();
            properties.load(in);

            driver = properties.getProperty("driver");
            url = properties.getProperty("url");
            username = properties.getProperty("username");
            password = properties.getProperty("password");

            //加載一次驅(qū)動
             Class.forName(driver);

        } catch (IOException e) {
            e.printStackTrace();
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }

    }
    //獲取連接
    public static Connection getConnection() throws SQLException {
        return DriverManager.getConnection(url,username,password);
    }
    //釋放連接
    public static  void release(Connection conn, Statement st, ResultSet rs){
        if(rs!=null){
            try {
                rs.close();
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
        }
        if(st!=null){
            try {
                st.close();
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
        }
        if(conn!=null){
            try {
                conn.close();
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
        }
    }

}

編寫測試類執(zhí)行sql語句

//執(zhí)行executeUpdate語句,實現(xiàn)增刪改
package connect_jdbc.utils;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class JdbcTest {
    public static void main(String[] args) throws SQLException {
        Connection connection =null;
        Statement st = null;
        ResultSet rs =null;

        try {
            connection = JdbcUtils.getConnection();
        } catch (SQLException throwables) {
            throwables.printStackTrace();
        }
        st = connection.createStatement();
        String sql = "insert  into  student (sno, sname, ssex, sclass, stel, sgroup, spassword)" +
                "values (1907040136,'賀子奇','男','1900144','15735116626',3,'123456')";
        int i = st.executeUpdate(sql);//返回值為整型,表示有幾行受影響
        if(i>0){
            System.out.println("插入成功!");
        }
        JdbcUtils.release(connection,st,rs);
    }
}

執(zhí)行select語句

//執(zhí)行executeQuery語句,實現(xiàn)查找
package connect_jdbc.utils;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class JdbcSelect {
    public static void main(String[] args) {
        Connection connection = null;
        Statement st = null;
        ResultSet res = null;
        try {
            connection = JdbcUtils.getConnection();
            st = connection.createStatement();
            String sqls = "select * from student";
            res = st.executeQuery(sqls);//返回值為查找的結(jié)果集
            while (res.next())//進行結(jié)果集的輸出
            {
                System.out.println(res.getObject("sno")+" "+res.getObject("sname"));
            }
        } catch (SQLException throwables) {
            throwables.printStackTrace();
        }

        JdbcUtils.release(connection,st,res);
    }
}

sql注入的問題及解決

問題描述:在使用statement函數(shù)執(zhí)行sql操作時,當輸入sql語句為:’ ‘or’1=1’或者’ 'or’values>0’時則會發(fā)生恒等于從而繞過查詢語句,會發(fā)生將結(jié)果集繞過密碼查詢出來,從而形成安全威脅。

解決辦法

將原先的statement函數(shù)改用preparedStatement函數(shù),避免了sql注入,查詢效率更高

示例:

package connect_jdbc.utils;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

public class JdbcTestSe {
    public static void main(String[] args) {
        Connection connection =null;
        PreparedStatement statement = null;
        ResultSet res = null;
        try {
            connection = JdbcUtils.getConnection();
            //與statement的區(qū)別,要使用?占位符代替參數(shù),進行一次預編譯
            String sql = "insert  into  student (sno, sname, ssex, sclass, stel, sgroup, spassword)" +
                    "values (?,?,?,?,?,?,?)";
            //手動給每一個參數(shù)(?)賦值
            statement=connection.prepareStatement(sql);
            statement.setString(1,"1907040124");
            statement.setString(2,"薛曉軍");
            statement.setString(3,"男");
            statement.setString(4,"19070144");
            statement.setString(5,"15735116626");
            statement.setString(6,"3");
            statement.setString(7,"123456");
			//執(zhí)行
            int i = statement.executeUpdate();
            if(i>0)
            {
                System.out.println("插入成功!");
            }

        } catch (SQLException throwables) {
            throwables.printStackTrace();
        }

        JdbcUtils.release(connection,statement,res);
    }
}

關(guān)于“如何實現(xiàn)MySQL安裝與idea的連接”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI