JDBC连接MySQL数据库及演示样例

发表于:2014-9-23 10:32

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:mfrbuaa    来源:51Testing软件测试网采编

  4、编写JDBC连接MySQL数据库的实例详细代码,JDBC_Test.java:
  详细代码:
  <pre name="code" class="java">package chp07;
  import java.sql.Connection;
  import java.sql.DriverManager;
  import java.sql.ResultSet;
  import java.sql.SQLException;
  import java.sql.Statement;
  public class JDBC_Test {
  // 创建静态全局变量
  static Connection conn;
  static Statement st;
  public static void main(String[] args) {
  insert(); //插入加入记录
  update(); //更新记录数据
  delete(); //删除记录
  query(); //查询记录并显示
  }
  /* 插入数据记录,并输出插入的数据记录数*/
  public static void insert() {
  conn = getConnection(); // 首先要获取连接,即连接到数据库
  try {
  String sql = "INSERT INTO staff(name, age, sex,address, depart, worklen,wage)"
  + " VALUES ('Tom1', 32, 'M', 'china','Personnel','3','3000')"; // 插入数据的sql语句
  st = (Statement) conn.createStatement(); // 创建用于运行静态sql语句的Statement对象
  int count = st.executeUpdate(sql); // 运行插入操作的sql语句,并返回插入数据的个数
  System.out.println("向staff表中插入 " + count + " 条数据"); //输出插入操作的处理结果
  conn.close(); //关闭数据库连接
  } catch (SQLException e) {
  System.out.println("插入数据失败" + e.getMessage());
  }
  }
  /* 更新符合要求的记录,并返回更新的记录数目*/
  public static void update() {
  conn = getConnection(); //相同先要获取连接,即连接到数据库
  try {
  String sql = "update staff set wage='2200' where name = 'lucy'";// 更新数据的sql语句
  st = (Statement) conn.createStatement(); //创建用于运行静态sql语句的Statement对象,st属局部变量
  int count = st.executeUpdate(sql);// 运行更新操作的sql语句,返回更新数据的个数
  System.out.println("staff表中更新 " + count + " 条数据"); //输出更新操作的处理结果
  conn.close(); //关闭数据库连接
  } catch (SQLException e) {
  System.out.println("更新数据失败");
  }
  }
  /* 查询数据库,输出符合要求的记录的情况*/
  public static void query() {
  conn = getConnection(); //相同先要获取连接,即连接到数据库
  try {
  String sql = "select * from staff"; // 查询数据的sql语句
  st = (Statement) conn.createStatement(); //创建用于运行静态sql语句的Statement对象,st属局部变量
  ResultSet rs = st.executeQuery(sql); //运行sql查询语句,返回查询数据的结果集
  System.out.println("最后的查询结果为:");
  while (rs.next()) { // 推断是否还有下一个数据
  // 依据字段名获取对应的值
  String name = rs.getString("name");
  int age = rs.getInt("age");
  String sex = rs.getString("sex");
  String address = rs.getString("address");
  String depart = rs.getString("depart");
  String worklen = rs.getString("worklen");
  String wage = rs.getString("wage");
  //输出查到的记录的各个字段的值
  System.out.println(name + " " + age + " " + sex + " " + address
  + " " + depart + " " + worklen + " " + wage);
  }
  conn.close(); //关闭数据库连接
  } catch (SQLException e) {
  System.out.println("查询数据失败");
  }
  }
  /* 删除符合要求的记录,输出情况*/
  public static void delete() {
  conn = getConnection(); //相同先要获取连接,即连接到数据库
  try {
  String sql = "delete from staff  where name = 'lili'";// 删除数据的sql语句
  st = (Statement) conn.createStatement(); //创建用于运行静态sql语句的Statement对象,st属局部变量
  int count = st.executeUpdate(sql);// 运行sql删除语句,返回删除数据的数量
  System.out.println("staff表中删除 " + count + " 条数据\n"); //输出删除操作的处理结果
  conn.close(); //关闭数据库连接
  } catch (SQLException e) {
  System.out.println("删除数据失败");
  }
  }
  /* 获取数据库连接的函数*/
  public static Connection getConnection() {
  Connection con = null; //创建用于连接数据库的Connection对象
  try {
  Class.forName("com.mysql.jdbc.Driver");// 载入Mysql数据驱动
  con = DriverManager.getConnection(
  "jdbc:mysql://localhost:3306/myuser", "root", "root");// 创建数据连接
  } catch (Exception e) {
  System.out.println("数据库连接失败" + e.getMessage());
  }
  return con; //返回所建立的数据库连接
  }
  }
  项目部署到server,然后执行结果:
33/3<123
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号