本文目錄一覽:
- 1、JSP連接MySQL
- 2、jsp怎麼連接mysql數據庫代碼
- 3、jsp怎麼連接mysql數據庫
- 4、jsp連接數據庫方法(詳細的)
- 5、求jsp與mysql連接的代碼
- 6、求jsp連接mysql的完整代碼及說明!
JSP連接MySQL
不是放到tomcat目錄下,而是放到項目所在的webroot-webinf-lib下
————-
你用的是eclipse還是MyEclipse 啊?
如果是後者的話,發布項目的時候會自動把workspace的項目拷貝到tomcat的webapps目錄下。
jsp怎麼連接mysql數據庫代碼
%@ page language=”java” import=”java.util.*” pageEncoding=”utf-8″%
%@ page import=”java.sql.*” %
body
%
String driver = “com.mysql.jdbc.Driver”;
// URL指向要訪問的數據庫名test1
String url = “jdbc:mysql://127.0.0.1:3306/test”;
// MySQL配置時的用戶名
String user = “root”;
// Java連接MySQL配置時的密碼
String password = “111”;
try {
// 1 加載驅動程序
Class.forName(driver);
// 2 連接數據庫
Connection conn = DriverManager.getConnection(url, user, password);
// 3 用來執行SQL語句
Statement statement = conn.createStatement();
// 要執行的SQL語句
String sql = “select * from login”;
ResultSet rs = statement.executeQuery(sql);
String name = null;
String mima=null;
while (rs.next()) {
name = rs.getString(“userName”);
mima = rs.getString(“passWord”);
out.println(name+”\t”+mima);
}
rs.close();
conn.close();
} catch (ClassNotFoundException e) {
System.out.println(“Sorry,can`t find the Driver!”);
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
%
/body
jsp怎麼連接mysql數據庫
我寫的一個用JSP連接MySQL數據庫的代碼。
要正確的使用這段代碼,你需要首先在MySQL數據庫里創建一username表,表裡面創建兩個字符型的字段,字段名分別為:uid,pwd,然後插入幾條測試數據。
以下用兩種方式來實現JSP連接MySql數據庫。
第一種方式,用JSP實現。
%@ page contentType=”text/html; charset=gb2312″ language=”java”
import=”java.sql.*”%
%
//**************************************
********* JDBC_ODBC連接MySql數據庫,不需要設置數據源
*********************************/
//********** 數據庫連接代碼 開始 ******/
//以下幾項請自行修改
String server=”localhost”; //MYSQL 服務器的地址
String dbname=”test”; //MYSQL 數據庫的名字
String user=”root”; //MYSQL 數據庫的登錄用戶名
String pass=”chfanwsp”; //MYSQL 數據庫的登錄密碼
String port=”3306″; //SQL Server 服務器的端口號,默認為1433
//數據庫連接字符串
String url =”jdbc:mysql://”+server+”:”+port+”/”+dbname+”?user=”+user+
“password=”+pass+”useUnicode=truecharacterEncoding=GB2312”;
//加載驅動程序
Class.forName(“org.gjt.mm.mysql.Driver”).newInstance();
//建立連接
Connection conn= DriverManager.getConnection(url);
//創建語句對象
Statement stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,
ResultSet.CONCUR_UPDATABLE);
// **** 數據庫連接代碼 結束 *******
String sql=”select * from username”;
ResultSet rs=stmt.executeQuery(sql);
//rs.first();
while(rs.next()){
out.print(“用戶名:”);
out.print(rs.getString(“uid”)+” 密碼:”);
out.println(rs.getString(“pwd”)+”
“);
}
rs.close();
stmt.close();
conn.close();
%
第二種方式,用JavaBean來實現。請看代碼:
DBConnMySql.java
編譯以後的Class文件應該放在WEB-INF\classes\conn目錄下。
package conn; //導入包
import java.sql.*; //導入數據庫操作的類
public class DBConnMySql //構造方法,初始化
{
private Connection conn; //連接對象
private Statement stmt; //語句對象
private ResultSet rs; //結果集對象
private String MySqldriver;//MYSQL Server驅動程序字符串
private String MySqlURL; //MYSQL Server連接字符串
//********************************
*用 org.gjt.mm.mysql.Driver 驅動
* 該方法取得連接所需各種參數,組成連接字符串,然後再建立連接
* server;dbname,user,pass,port 分別表示MYSQL 服務器的地址,
* 數據庫,用戶名,密碼,端口
**********************************/
public Connection getConnToMySql(String server,String dbname,
String user,String pass,String port){
//MYSQl驅動程序
MySqldriver = “org.gjt.mm.mysql.Driver”;
MySqlURL = “jdbc:mysql://”; //連接字符串一部分
try{
//完整的連接字符串
MySqlURL =MySqlURL+server+”:”+port+”/”+dbname+
“?user=”+user+”password=”+pass+
“useUnicode=truecharacterEncoding=GB2312”;
Class.forName(MySqldriver);
conn = DriverManager.getConnection(MySqlURL);
}catch(Exception e){
System.out.println(“操作數據庫出錯,請仔細檢查”);
//System.err.println(e.getMessage());
}
return conn;
}
//關閉數據庫連接
public void close()
{
try{
//rs.close();
//stmt.close();
conn.close();
}catch(SQLException sqlexception){
sqlexception.printStackTrace();
}
}
}
這個文件只是實現了數據庫的連接,下面我們再寫一個測試文件。
就是用sql語句從數據庫里查詢出記錄,以驗證我們數據庫的連接是否成功。
connmysql.jsp文件源代碼如下:
%@ page contentType=”text/html; charset=gb2312″ language=”java”
import=”java.sql.*” %
%
//以下幾項請自行修改
String server=”localhost”; //MYSQL 服務器的地址
String dbname=”test”; //MYSQL 數據庫的名字
String user=”root”; //MYSQL 數據庫的登錄用戶名
String pass=”chfanwsp”; //MYSQL 數據庫的登錄密碼
String port=”3306″; //SQL Server 服務器的端口號,默認為1433
Connection conn=DBConn.getConnToMySql(server,dbname,user,pass,port);
Statement stmt=conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,
ResultSet.CONCUR_READ_ONLY);
String sql=”select * from username”;
String sql1=”insert into username (uid,pwd) values(‘夢想年華’,’夢想年華’)”;
stmt.executeUpdate(sql1);
ResultSet rs=stmt.executeQuery(sql);
while(rs.next()){
out.print(“用戶名:”);
out.print(rs.getString(“uid”)+” 密碼:”);
out.println(rs.getString(“pwd”)+”
“);
}
//rs.close();
//stmt.close();
//conn.close();
DBConn.close();
%
jsp連接數據庫方法(詳細的)
上面的給出了jsp內嵌java的最初模式,現在一般是三層結構了即MVC結構,就這個例子我來給你解釋下是怎麼做的,java對連接數據庫提供了統一的接口,各個數據庫廠商根據提供的接口規範開發自己的連接方法順序如下:1、用Class.forName()方法加載驅動:Class.forName(“com.microsoft.jdbc.sqlserver.SQLServerDriver”).newInstance(); 黑體部分為數據庫廠商自己開發的驅動。2、定義好連接數據庫的url地址,連接串String url=”jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=pubs”;黑體部分為固定寫法不用理會。回到你最初的問題,如何創建數據庫,這裡你可以去baidu下每個數據庫創建的方法,一般數據庫安裝的時候都有默認的數據庫名,和對應的系統管理員工號和密碼,DatabaseName=pubs這裡說明sql serv 2000中建立了一個名字叫pubs的數據庫jdbc:microsoft:sqlserver://localhost:1433固定寫法唯一不同的是1433端口號,可能你在安裝sql serv 2000的時候改變了該端口號為1500那麼這裡就應該為jdbc:microsoft:sqlserver://localhost:15003、定義好DatabaseName=pubs的登錄用戶名和密碼 String user=”sa”;用戶名
String password=””;密碼4、創建Connection對象,通過調用DriverManager.getConnection方法獲得。 Connection conn= DriverManager.getConnection(url,user,password);黑體部分就是你定義好的連接串,用戶名,密碼,不可改變順序。到這裡為止數據庫就連接上了,但是連接好了數據庫還要做點什麼,比如打印出來,接下看。5、通過獲得的Connection對象conn創建Statement 對象stmtStatement stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);黑體部分是定義ResultSet的一些屬性的,具體含義可以參考JDK的api。6、定義好你準備取得數據的sql語句,比如下面 select * from test說明想從test表中取得所有的數據,關於sql語句可以去查找相關數據庫資料。 String sql=”select * from test”;定義好語句後,就用上一步創建好的Statement 對象stmt來執行這個sql語句,並返回一個ResultSet對象。
ResultSet rs=stmt.executeQuery(sql);執行完這步後rs中已經取得了test表所有的數據,那麼接下來要展現在網頁上。7、rs.next()對你取得的記錄集做一個循環直到沒有值為止,rs.getString(1)代表你test表中的第一個字段rs.getString(2)代表你test中的第二個字段,如果還有更多字段可以繼續rs.getString(3)..rs.getString(N) while(rs.next()) {%
您的第一個字段內容為:%=rs.getString(1)%
您的第二個字段內容為:%=rs.getString(2)%
%}%8、當所有數據展現完畢,調用close()方法將所有資源關閉。 rs.close();
stmt.close();
conn.close();回顧下大致過程:加載驅動 Class.forName();定義好相關的數據,調用DriverManager.getConnection(driver,user,password)獲得一個數據庫連接conn通過conn創建Statement對象stmt,conn.createStatement();通過stmt執行定義好的sql語句獲得數據集ResultSet rs=stmt.executeQuery(“select * from test”);通過rs.next()方法循環遍曆數據集的數據,通過rs.getString(1)獲得第一條數據的第一個字段內容,這裡要注意的是getString是對應數據庫是字符類型,如果test表的第一個字段不是字符類型則用rs.getInt(1)獲得。展現完畢後關閉所有資源conn stmt rs close方法。
求jsp與mysql連接的代碼
import java.sql.*;
public class DbOperator {
public final String DB_USER= “root”;
public final String DB_PWD = “1234”;
public final String DB_HOST = “127.0.0.1”;
public final String DB_NAME = “test”;
public DbOperator() {
}
/**
* 得到數據庫連接
* @return Connection
*/
public Connection getConnection()
{
Connection conn = null;
String url = “jdbc:mysql://”+this.DB_HOST+”/”+this.DB_NAME+”?useUnicode=truecharacterEncoding=GBK”;
try
{
Class.forName(“com.mysql.jdbc.Driver”).newInstance();
conn = java.sql.DriverManager.getConnection(url, this.DB_USER, this.DB_PWD);
}catch(Exception e)
{
e.printStackTrace();
}
return conn;
}
}
使用的
Connection conn = dbOperator.getConnection();
try
{
Statement st = conn.createStatement();
String sql = ” select * from user where username ='” + username + “‘ and pwd ='” + pwd + “‘”;
ResultSet rs = st.executeQuery(sql);
if(rs.next())
{
userInfo = new UserInfo();
userInfo.setAge(rs.getString(“age”));
userInfo.setId(rs.getInt(“id”));
userInfo.setPwd(rs.getString(“pwd”));
userInfo.setSex(rs.getString(“sex”));
userInfo.setTheName(rs.getString(“the_name”));
userInfo.setUserName(rs.getString(“username”));
}
rs.close();
st.close();
conn.close();
}catch(Exception e)
{
e.printStackTrace();
}
return userInfo;
求jsp連接mysql的完整代碼及說明!
我給你 後台通用的增刪改 方法 , sql 語句我就寫了,自己去調用吧
%
private static Connection con = null;
private static String CONSTR = “jdbc:mysql://localhost:3306/student”;
private static String CLASSNAME = “com.mysql.jdbc.Driver”;
private static PreparedStatement prst = null;
private static ResultSet rs = null;
/**
* @param args
* @throws SQLException
* @throws ClassNotFoundException
* @throws ClassNotFoundException
* @throws SQLException
* @throws IllegalAccessException
* @throws InstantiationException
*/
/**
* 獲得連接
* @return
* @throws ClassNotFoundException
* @throws SQLException
* @throws InstantiationException
* @throws IllegalAccessException
*/
public Connection getConnection(){
try {
Class.forName(CLASSNAME).newInstance();//加載驅動
con = DriverManager.getConnection(CONSTR, “數據庫用戶名”,”密碼”);//得connection
} catch (InstantiationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalAccessException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return con;
}
/**
* 增、刪、改
* @throws SQLException
* @throws IllegalAccessException
* @throws InstantiationException
* @throws ClassNotFoundException
*/
public void insertUpdate(String sql,Object…param){
getConnection();
try {
prst = con.prepareStatement(sql);
bindParam(param);
prst.executeUpdate(sql);
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
/**
* 查找方法
* @param sql
* @param param
* @return
* @throws SQLException
* @throws IllegalAccessException
* @throws InstantiationException
* @throws ClassNotFoundException
*/
public ResultSet search(String sql,Object…param){
getConnection();
try {
prst = con.prepareStatement(sql);
bindParam(param);
rs = prst.executeQuery();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return rs;
}
/**
* 綁定參數
* @param param
* @throws SQLException
*/
private void bindParam(Object… param) throws SQLException {
if(param!=null){
for(int i=0;iparam.length;i++){
if(param[i] instanceof java.util.Date){
java.util.Date dd = (java.util.Date)param[i];
java.sql.Date sd = new java.sql.Date(dd.getTime());
prst.setDate(i,sd);
}else{
prst.setObject(i,param[i]);
}
}
}
}
/**
* 釋放資源
* @throws SQLException
*/
public void realse(ResultSet rs) throws SQLException{
if(rs!=null){
rs.close();
}
if(prst!=null){
prst.close();
}
if(con!=null){
con.close();
}
}
public void realse() throws SQLException{
realse(null);
}
%
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/242695.html