JDBC

原文链接:原文链接若有侵犯告知删帖

JAVA 访问数据库的技术:

Jdbc是一种Java连接数据库技术(Java database connectity), 它是 Java 提供的一些接口,这些接口大部分是数据库厂商提供的(jar包),我们要做的,是连接数据库以后,如何使用Java代码从数据库中存取数据!

 

 

Jdbc开发步骤

1. 引包:

2. 开启MySQL服务,

如何没有开启会报错:

3.准备好数据库

4.进入开发阶段

4.1注册数据库驱动

//MySQL驱动固定写法!注意是”MySQL数据库的驱动”

Class.forName("com.mysql.jdbc.Driver");

 

4.2和数据库建立连接

连接数据库必要的参数:

URL: 访问数据库的地址:写法:

            jdbc:mysql://数据库所在Ip地址:数据库端口/数据库的名字

name : 要连接的数据库的账户名

password : 要连接数据库的用户密码

//找到本机的数据库应用,3306是数据库的默认端口 8080是tomkat的默认端口
 

 
  1. String url = "jdbc:mysql://localhost:3306/student";

  2. String name = "root";//将要连接数据库的账户

  3. String password = "root";//将要连接数据库的密码

  4. Connection connection = DriverManager.getConnection(url,name,password);

 

4.3获得执行sql语句的对象

用于执行SQL语句

PreparedStatement接口继承了Statement,
Statement(固定),和 PreparedStatement(可变参数) 是SQL语句的两种执行方式

 

1.在遇到要执行的SQL语句是带可变参数的时候,就用PreparedStatement对象,应为PreparedStatement可以用占位符将SQL语句加入可变参数!:

 
  1. String sql = "insert into user(sno,name,age)values(?,?,?)";//定义一个要执行的SQL语句

  2. PreparedStatement ps = connection.prepareStatement(sql);

  3. ps.setString(1,student.getSno());//设置SQL语句的第一个参数

  4. ps.setString(2,student.getName());//设置SQL语句的第二个参数

  5. ps.setInt(3,student.getAge());//设置SQL语句的第三个参数

2.当要执行的SQL语句的是不带可变参数的时(就是SQL语句不变时!):

 

 
  1. String sql = "SELECT * FROM user";

  2. Statement statement = connection.createStatement();//sql语句的执行对象

  3. ResultSet row = statement.executeQuery(sql);//执行SQL语句

 

PreparedStatement 和Statement的区别:

PreparedStatement:用户通过你系统输入变量时,变量将加入你的SQL语句,这样就能在不知道你的用户输入的情况下,获取信息

4.4执行SQL语句

两种语句:

  1).不用返回数据库信息:

增,删,改

exexuteUpdate() 方法 : 返回一个整形(对数据库影响的行数)

2).需要返回数据库信息:

exexuteQuery() 方法 : 返回一个结果集对象(Resultest 在数据库中查到的一条数据)

读取返回对象集中的数据的方法: (就是集合的迭代器)

Resultest.next()能够返回给你还有没有记录,

getObjeck方法,读取一条记录里面字段所对应的值 

 

4.5处理执行后的结果

调用Dao的方法后返回一个结果给servlet 让servlet进行处理!:如:

 
  1. int row = UserDAD.insert(student);

  2. if (row==1){

  3. jsonObject.put("code",1);

  4. jsonObject.put("msg","添加成功");

  5. jsonObject.put("data",student);

  6. }else {

  7. jsonObject.put("code",2);

  8. jsonObject.put("msg","添加失败");

  9. }

 

4.6 释放资源

将用到的传输有关的对象再传输完成后统统释放!  如:

 
  1. ps.close();

  2. connection.close();

原文链接:原文链接

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值