一、获取数据库连接

  要对MySql数据库内的数据进行增删改查等操作,首先要获取数据库连接

  JDBC:Java中连接数据库方式

具体操作如下:

    获取数据库连接的步骤:

      1、先定义好四个参数

      String username="root";   //连接数据库的用户名
String password="root"; //连接数据库的密码
//连接MySql数据库的url,不同数据库url不同,语法:jdbc:子协议:厂商内容
String url="jdbc:mysql://localhost:3306/MyBookStore";
//数据库驱动程序的全类名,加载相应数据库的jar包,在Web App Libraries中找到driver.class复制其全类名即可
String driver="com.mysql.jdbc.Driver";

      2、加载驱动类 

      Class.forName(driver);

      3、获取数据库连接,对数据库的一切操作都是从Connection连接开始的

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

         4.Statement由connection对象创建,然后通过Statement执行具体的sql语句

        (在实际开发中,由于Statement存在漏洞,容易发生sql注入,通常使用PreparedStatement来操作sql语句)

       Statement statement = connection.createStatement();

二、数据库的增删改查操作

  1、增加数据 

         String sql1="insert into dept values(null,'财务部门')";
int i = statement.executeUpdate(sql1);
       //executeUpdate()是执行增删改操作的方法,返回值为int类型,返回数据库中受到影响的行数
System.out.println(i);

  2、删除数据

         String sql2="delete from dept where id=2";
int i2=statement.executeUpdate(sql2);
System.out.println(i2);

  3、修改数据

         String sql3="update dept set dept_name='人事部门' where id=4";
int i3=statement.executeUpdate(sql3);
System.out.println(i3);

  4、查询数据

         String sql4="select id,dept_name from dept";
ResultSet resultSet=statement.executeQuery(sql4);
       //executeQuery()是执行查询操作的方法,返回值为ResultSet类型,返回查询的结果集,相当于一个虚拟的表格
while (resultSet.next()) {
int id=resultSet.getInt("id");
String deptName=resultSet.getString("dept_name");
System.out.println(id+":"+deptName);
}

  5、通过对象封装结果集,并利用集合存储对象

      String sql4="select id,dept_name from dept";
ResultSet resultSet=statement.executeQuery(sql4);
List<Department> list=new ArrayList<Department>();
while (resultSet.next()) {
int id=resultSet.getInt("id");
String deptName=resultSet.getString("dept_name");
Department department=new Department(); //创建用来封装结果集记录的对象
department.setId(id);
department.setDeptName(deptName);
list.add(department); //将封装好的对象添加到list集合中
}
//Department类中重写了toString()方法,使该方法返回对象中的某些属性,而不是地址
//System.out.println()输出list中的内容时,会调用list内存储的Department对象的toString()方法
System.out.println(list);

注意:通过PreparedStatement执行sql语句时,示例如下:

  PreparedStatement需要对sql语句进行预编译,因此需要先将sql语句字符串传递给PreparedStatement对象,这样就避免了Statament的sql注入漏洞

      PreparedStatement preparedStatement=null;
ResultSet rs=null; String sql="select id,dept_name from dept where id=? "; //?为占位符
preparedStatement=connection.prepareStatement(sql); //此处需要给prepareStatement()方法传递参数(sql语句)
preparedStatement.setInt(1,5); //参数表示为第一个占位符赋值
rs=preparedStatement.executeQuery(); //此处执行无参的executeQuery()方法

     

通过jdbc连接MySql数据库的增删改查操作的更多相关文章

  1. java jdbc 连接mysql数据库 实现增删改查

    好久没有写博文了,写个简单的东西热热身,分享给大家. jdbc相信大家都不陌生,只要是个搞java的,最初接触j2ee的时候都是要学习这么个东西的,谁叫程序得和数据库打交道呢!而jdbc就是和数据库打 ...

  2. 【转载】通过JDBC对MySQL数据库的增删改查

    通过JDBC进行简单的增删改查(以MySQL为例) 目录 前言:什么是JDBC 一.准备工作(一):MySQL安装配置和基础学习 二.准备工作(二):下载数据库对应的jar包并导入 三.JDBC基本操 ...

  3. 【C#】使用NHibernate连接MySQL数据库及增删改查

    学习资料 http://www.sikiedu.com/course/51/task/891/show https://www.codeproject.com/Articles/26123/NHibe ...

  4. 使用NHibernate连接MySQL数据库及增删改查

    学习资料 http://www.sikiedu.com/course/51/task/891/show https://www.codeproject.com/Articles/26123/NHibe ...

  5. C++ API方式连接mysql数据库实现增删改查

    这里复制的 http://www.bitscn.com/pdb/mysql/201407/226252.html 一.环境配置 1,装好mysql,新建一个C++控制台工程(从最简单的弄起,这个会了, ...

  6. 使用nodejs连接mysql数据库实现增删改查

      首先要有数据库 使用xampp 或者 phpstudy 可以傻瓜式安装 新建一个项目文件夹 之后在这个目录下初始化package.json (npm init) 先在项目中安装mysql 和 ex ...

  7. 连接mysql数据库实现增删改查(一)

    在python中我们通过pymysql来连接数据库,具体实现如下 ''' 连接mysql数据库 此类进行封装了一些基础的操作数据库方法 ''' import pymysql from Homework ...

  8. php 连接mysql数据库以及增删改查

    php 连接数据库 一般是用面向对象的方法,需要先创建一个对象,即造一个连接对象,然后再写sql语句,(增改查删),最后执行sql语句 其中在创建连接对象时 我们用到的是MySQLI  是不区分大小写 ...

  9. php之PDO连接mysql数据库,增删改查等等操作实例

    我们使用传统的 mysql_connect .mysql_query方法来连接查询数据库时,如果过滤不严就有SQL注入风险,导致网站被攻击. 虽然可以用mysql_real_escape_string ...

随机推荐

  1. windows下安装 postgresql

    1. 下载PostgreSQL的源代码.解压. 2. 在Windows平台下编译需要跳过一个权限的检测,否则在编译的时候可能会出现错误. 在\src\backend\main\main.c文件中将   ...

  2. linux命令学习笔记(21):find命令之xargs

    xargs是一条Unix和类Unix操作系统的常用命令.它的作用是将参数列表转换成小块分段传递给其他命令,以避免参数列表过长的问题 xargs的作用一般等同于大多数Unix shell中的反引号,但更 ...

  3. pthread_cond_wait()用法分析

    很久没看APUE,今天一位朋友问道关于一个mutex的问题,又翻到了以前讨论过的东西,为了不让自己忘记,把曾经的东西总结一下. 先大体看下网上很多地方都有的关于pthread_cond_wait()的 ...

  4. ffmpeg处理rtmp/文件/rtsp的推流和拉流

    ffmpeg处理rtmp/文件/rtsp的推流和拉流   本demo演示了利用ffmpeg从服务器拉流或本地文件读取流,更改流url或文件类型名称发送回服务器或存到本地的作用. 由于本程序只写了3个小 ...

  5. BZOJ4695:最假女选手

    浅谈区间最值操作和历史最值问题:https://www.cnblogs.com/AKMer/p/10225100.html 题目传送门:https://lydsy.com/JudgeOnline/pr ...

  6. 通用RowMapper封装查询结果到自定义类中

    package object; import java.lang.reflect.Field;import java.sql.ResultSet;import java.sql.SQLExceptio ...

  7. 使用cmd命令行方式登录ftp上传下载数据

    部分用户在使用ftp工具登录空间上传下载过程中经常会遇到各种问题,如主动模式,被动模式,以及其他导致无法登陆ftp .上传数据.下载数据的问题,这时候不妨使用一下命令行方式.命令行下可以避免很多由于f ...

  8. 【转】 Pro Android学习笔记(三八):Fragment(3):基础小例子-续

    目录(?)[-] Step 2实现Fragment指定调用类TitleFragment onInflate和onAttach onCreate和onCreateView onActivityCreat ...

  9. 人物-IT-张朝阳:张朝阳

    ylbtech-人物-IT-张朝阳:张朝阳 张朝阳,1964年10月31日出生在陕西省西安市,搜狐公司董事局主席兼首席执行官.1986年毕业于清华大学物理系,并于同年考取李政道奖学金赴美留学.1993 ...

  10. 第二课 go语言的结构

    1 go 语言结构 package main import "fmt" func main() { /* 这是我的第一个简单的程序 */ fmt.Println("Hel ...