大家好,Java如何连接数据库。之前学过.net语言的数据库操作,感觉就是一通百通,大同小异。

  JDBC是Java数据库连接技术的简称,提供连接各种常用数据库的能力。

    JDBC API (主要功能:与数据库建立连接、执行语句、处理结果):

      提供者:Sun公司

      内容:供程序员调用的接口与类,集成在java.sql和javax.sql(后面的x是extend,扩展的意思)。如:

        DriverManager类(管理各种不同的JDBC驱动),

        Connection接口(连接数据、传送数据),

        statement接口(执行SQL语句),

        ResultSet接口(根据statement返回的结果集,来处理结果)。

  编写步骤:

    1.加载JDBC驱动;

    2.创建数据库连接对象;

    3.创建命令对象statement,来执行SQL语句并返回结果集;

    4.ResultSet通过返回的结果集,来处理结果;

    5.关闭数据库连接,释放资源。

  举一个验证用户登录的例子吧:

  

package jdbc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Scanner; /**
* JDBC连接数据库.java
* 2017-1-6 上午11:14:48
* John
*/
public class Test {
public static void main(String[] args) {
Scanner input=new Scanner(System.in);
System.out.println("请输入用户名:");
String username=input.next();
System.out.println("请输入密码:");
String userpwd=input.next();
//1.加载JDBC驱动
try {
Class.forName("com.mysql.jdbc.Driver");//MySQL使用的驱动器 //oracle驱动器:oracle.jdbc.driver.OracleDriver
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//2.创建数据库连接对象
Connection conn=null;
Statement stat=null;
ResultSet rs=null;
try {
//mysql连接URL编写格式为:jdbc:mysql://主机名称:连接端口/数据库名称
              //oracle连接URL编写格式为: oracle jdbc:oracle:thin:@127.0.0.1:1521:pet
String url="jdbc:mysql://localhost:3306/Pet";
conn=DriverManager.getConnection(url, "root","123456");
//3.创建命令对象statement
stat=conn.createStatement();
//4.执行命令,并返回结果集
String sql="select count(1) as cnt from users where UserName='"+username+"' and userpwd='"+userpwd+"'";
rs=stat.executeQuery(sql);
while(rs.next()){
int count=rs.getInt("cnt");
if (count==1) {
System.out.println("登录成功!");
}else {
System.out.println("登录失败!");
}
}
} catch (SQLException e) { //此处记住要对异常进行处理
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
//5.关闭数据库连接
try {
conn.close();
stat.close();
rs=null;
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}

  以上是我的个人观点,有异议的地方望大家指正,共同学习,共同进步!

  

  

  

最新文章

  1. 公司内部培训SQL Server传统索引结构PPT分享
  2. openstack-keystone
  3. xtrabackup备份rds记录
  4. Java基础之在窗口中绘图——填充星型(StarApplet 2 filled stars)
  5. [Z] Windows 8/10 audio编程
  6. Write operations are not allowed in read-only mode (FlushMode.NEVER/
  7. (转)ASP.NET里面简单的记住用户名和密码
  8. (转)CentOS下用yum搭建LNMP服务器
  9. ZigZag-LeetCode
  10. HDU 4917 Permutation
  11. (NO.00005)iOS实现炸弹人游戏(八):游戏主角(一)
  12. day08_Servlet学习笔记
  13. Feign get接口传输对象引发一场追寻
  14. CentOS7 下源代码安装mysql5.6
  15. [svc]ext4文件删除&访问原理
  16. 最小生成树 - 普里姆 - 边稠密 - O(N ^ 2)
  17. marquee 标签的鼠标放上去滚动效果 鼠标离开继续滚动
  18. Tomcat gzip果然强大,js文件压缩率50%以上
  19. TCP和UDP发送数据包的大小问题
  20. loadrunner测试ajax框架

热门文章

  1. HTML URL地址解析
  2. 了不起的 nodejs-TwitterWeb 案例 bug 解决
  3. 【NLP】揭秘马尔可夫模型神秘面纱系列文章(一)
  4. 【云知道】LoadRunner 录制问题集锦
  5. vs15 preview5 离线安装包
  6. Exception in thread "main" java.lang.NoSuchMethodError: org.objectweb.asm.ClassWriter.<init>(I)V
  7. C# Entity Framework并发处理
  8. Atitit.技术管理者要不要自己做开发??
  9. TFS2013 设置签出独占锁
  10. 解决mysql插入数据时出现Incorrect string value: '\xF0\x9F...' for column 'name' at row 1的异常