欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2022年01月05日 16:03:16   作者:流光拾貝  
本文主要介紹了MySQL安裝與idea的連接實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

MySQL安裝與idea的連接

--編輯my.ini配置文件內(nèi)容(Mysql 8.0以上不需要,直接安裝即可)
[mysql]
# 設(shè)置mysql客戶端默認(rèn)字符集
default-character-set=utf8 
[mysqld]
#設(shè)置3306端口
port = 3306 
# 設(shè)置mysql的安裝目錄
basedir=E:\MySQL5.7.13\mysql-5.7.13-winx64
# 設(shè)置mysql數(shù)據(jù)庫的數(shù)據(jù)的存放目錄
datadir=E:\MySQL5.7.13\mysql-5.7.13-winx64\data
# 允許最大連接數(shù)
max_connections=200
# 服務(wù)端使用的字符集默認(rèn)為8比特編碼的latin1字符集
character-set-server=utf8
# 創(chuàng)建新表時將使用的默認(rèn)存儲引擎
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.導(dǎo)入數(shù)據(jù)庫驅(qū)動

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

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

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

請?zhí)砑訄D片描述

連接過程若出現(xiàn)驅(qū)動問題,需要注意查看驅(qū)動是否添加為庫,英文版(add as library),查看驅(qū)動版本的問題(下載驅(qū)動需要對應(yīng)與數(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操作時,當(dāng)輸入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ù),進行一次預(yù)編譯
            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)于MySQL安裝與idea的連接實現(xiàn)的文章就介紹到這了,更多相關(guān)MySQL安裝與idea連接內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java8實現(xiàn)Stream流的合并的方法展示

    Java8實現(xiàn)Stream流的合并的方法展示

    本文介紹了Java8中Stream流的合并方法,包括concat()、flatMap()和reduce()三種方法。其中,concat()方法可以將兩個Stream流合并成一個,flatMap()方法可以將一個Stream流中的元素映射成多個Stream流并合并成一個,reduce()方法可以將Stream流中的元素逐個合并成一個結(jié)果
    2023-05-05
  • Spring思維導(dǎo)圖助你輕松學(xué)習(xí)Spring

    Spring思維導(dǎo)圖助你輕松學(xué)習(xí)Spring

    這篇文章主要為大家詳細介紹了Spring思維導(dǎo)圖,幫助你輕松學(xué)習(xí)Spring的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • spring aop execution表達式的用法

    spring aop execution表達式的用法

    這篇文章主要介紹了spring aop execution表達式的用法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • 基于Java方式實現(xiàn)數(shù)據(jù)同步

    基于Java方式實現(xiàn)數(shù)據(jù)同步

    這篇文章主要為大家詳細介紹了基于Java方式實現(xiàn)數(shù)據(jù)同步,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • springboot項目獲取請求頭當(dāng)中的token的方法

    springboot項目獲取請求頭當(dāng)中的token的方法

    本文主要介紹了springboot項目獲取請求頭當(dāng)中的token的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-11-11
  • java 解析user-agent 信息

    java 解析user-agent 信息

    這篇文章主要介紹了java 解析http user-agent的信息的相關(guān)資料,需要的朋友可以參考下
    2016-07-07
  • Java內(nèi)存模型相關(guān)知識總結(jié)

    Java內(nèi)存模型相關(guān)知識總結(jié)

    這篇文章主要介紹了Java內(nèi)存模型相關(guān)知識總結(jié),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-10-10
  • SpringBoot 文件或圖片上傳與下載功能的實現(xiàn)

    SpringBoot 文件或圖片上傳與下載功能的實現(xiàn)

    這篇文章主要介紹了SpringBoot 文件或圖片上傳與下載功能的實現(xiàn),本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-02-02
  • SpringBoot中@ConfigurationProperties注解實現(xiàn)配置綁定的三種方法

    SpringBoot中@ConfigurationProperties注解實現(xiàn)配置綁定的三種方法

    這篇文章主要介紹了SpringBoot中@ConfigurationProperties注解實現(xiàn)配置綁定的三種方法,文章內(nèi)容介紹詳細需要的小伙伴可以參考一下
    2022-04-04
  • Java并發(fā)之CAS原理詳解

    Java并發(fā)之CAS原理詳解

    這篇文章主要為大家詳細介紹了Java的CAS原理,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03

最新評論