使用JDBC编程-连接MySQL数据库

作者:李老师,吕老师              2019-09-23


 准备工作:

1、首先安装MySQL5.5.30

64位:链接:https://pan.baidu.com/s/1H99PH-jRq9OrWBMTA_Xo5g 提取码:6kmk 

32位:链接:https://pan.baidu.com/s/19bBx0s1hC4HWNdYNLB5DeQ 提取码:wdl5 

2、安装navicat for MySQL;

链接:https://pan.baidu.com/s/1OrM2Q6OSfz7AZojorW4P_A 提取码:70oy 

3、然后创建数据库-例如名字为Stu,创建表stu_info


编程:
1、打开Eclipse,创建Dynamic web project;

2、将连接MySQL数据库的jar包复制到webcontent->web-inf->lib下。并且右击该jar包,选择buildpath->add buildpath

jar包下载地址:链接:https://pan.baidu.com/s/1qlzUjQw3Jk9L2ig0dBlmyg  提取码:qf2i 

3、新建JSP文件,在page指令中,输入import="java.sql.*"

4、进行JDBC编程步骤大致如下:

4.1加载数据库驱动

Class.forName(driverClass)
上面的dirverClass就是数据库驱动类所对应的类路径字符串,根据不同数据库厂商提供的驱动也不同。

 这里连接MySQL数据库,字符串为:"com.mysql.jdbc.Driver"

4.2、通过DriverManager获取数据库的链接

DriverManager.getConnection(String url, Stirng user, String pass)
当使用DriverManager来获取链接,需要传入三个参数:分别是数据量的url、用户名、密码。

 连接MySQL数据库,参数分别为:"jdbc:mysql://localhost:3306/Stu"     "root"  "root" 

注意:密码可以修改为自己安装MySQL的时候的密码

4.3、通过Connection对象创建Statement对象,Connection创建Statement的方法如下三个:

createStatement()创建基本的Statement对象。
prepareStatement(String sql):根据传入的sql语句创建预编译的Statement对象。
prepareCall(String sql):根据传入的sql语句创建CallableStatement对象 

4.4 、Statement执行SQL语句,Statement有三大方法来执行SQL语句:

execute:可以执行任何SQL语句,单比较麻烦
executeUpdate:可以执行DML、DDL语句。执行DML返回受影响的SQL语句行数,执行DDL返回0;
executeQuery:只能执行查询语句,执行后返回代表查询结果的ResultSet对象。

4.5、操作结果集,针对ResultSet

主要移动指针和获得值
next、previous、first、last、beforeFrist、afterLast、absolute等移动指针的方法。
getXxx获得移动指针指向行,特定列、索引的值。使用列名作为获取值的参数可读性好、使用索引作为获取参数性能好。

4.6、释放资源

关闭结果集

关闭Statement对象

关闭Connection对象


 核心代码:

try {
Class.forName("com.mysql.jdbc.Driver");
conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/Stu", "root", "root");
}catch(Exception e) {
e.printStackTrace();
}
}
public boolean check(User user) throws SQLException {

String userName=user.getUsername();
String pwd=user.getPassword();
String cpwd=null;
boolean flag=false;

try {
PreparedStatement psmt=conn.prepareStatement("select * from stu_info where user=?");
psmt.setString(1, userName);
ResultSet rs=psmt.executeQuery();
while(rs.next()) {
cpwd=rs.getString(2);
}
}catch(Exception e) {
e.printStackTrace();
}finally {
conn.close();
}

posted @ 2019-09-23 21:12  天津天狮学院-Java  阅读(556)  评论(0编辑  收藏  举报