步骤:
1. 加载sql数据库驱动
Class.forName(“com.mysql.jdbc.Driver”);
2. 连接数据库
con = DriverManager.getConnection(url, username, pwd);
3.获得Statement
stmt = con.createStatement();
4.写入想要执行的sql语句
eg: String sql = “select * from student”;
5.操作数据库
为方面理解下面是本人操作的数据库内容:
package com.wql.jdbc; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement;/** * @author wql * */public class jdbc { public static void main(String[] args) { /// 加载sql数据库驱动 try { Class.forName("com.mysql.jdbc.Driver"); } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } Connection con = null; Statement stmt = null; ResultSet result = null; PreparedStatement pstm = null;// 预处理 String url = "jdbc:mysql://localhost:3306/work"; // 数据库所在位置 String username = "root"; // 数据库用户名 String pwd = "123456"; // 数据库密码 try { /// 连接数据库 con = DriverManager.getConnection(url, username, pwd); /// 获得Statement stmt = con.createStatement(); /// 写入想要执行的sql语句 String sql = "select * from student"; /// 获得sql语句执行后的集 result = stmt.executeQuery(sql); // 在控制台打印出数据库内容 System.out.println("学号" + " 姓名" + " 年 龄 " + " 性别"); while (result.next()) { int id = result.getInt(1); // 这里对应数据库中表的第一个字段属性,接受内容的属性要根据数据库的属性 String name = result.getString(2); String age = result.getString(3); String sex = result.getString(4); System.out.println(" " + id + " " + name + " " + age + " " + sex);/////////////////////下面有验证截图1 ///////////////////////// } // 用Statement向表中插入数据 String sql2 = "insert into student values(9,\"李丽\",\"1990-12-25\",\"女\")"; stmt.executeUpdate(sql2);// 更新数据/////////////////////下面有验证截图2 ///////////////////////// ///// 上面用Statement操作数据库十分麻烦,在一些特定场合可以使用预处理方法来操作数据库 String sql3 = "insert into student values(?,?,?,?)";/// 插入数据 pstm = con.prepareStatement(sql3); pstm.setInt(1, 10); /// 前面的数字1代码表中的第1字段,后面的9是要插入表中第1个字段的内容 pstm.setString(2, "流星雨"); pstm.setString(3, "1998-02-03"); pstm.setString(4, "男"); pstm.executeUpdate();/////////////////////下面有验证截图 ///////////////////////// } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }
截图1:
截图2:
截图3:
上面对数据库的操作可以举一反三,重点说下:预处理的好处:
jdbc连接预处理可以预防SQL注入,提高安全性。因为SQL语句在程序运行前已经进行了预编译,在程序运行时第一次操作数据库之前,SQL语句已经被数据库分析,编译和优化,对应的执行计划也会缓存下来并允许数据库已参数化的形式进行查询,当运行时动态地把参数传给PreprareStatement时, 即使参数里有敏感字符如 or’1=1’也数据库会作为一个参数一个字段的属性值来处理而不会作为一个SQL指令, 如此,就起到了SQL注入的作用了!
以上是jdbc连接操作mysql,直接操作和预处理方式的详细内容。更多信息请关注PHP中文网其他相关文章!

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于架构原理的相关内容,MySQL Server架构自顶向下大致可以分网络连接层、服务层、存储引擎层和系统文件层,下面一起来看一下,希望对大家有帮助。

在mysql中,可以利用char()和REPLACE()函数来替换换行符;REPLACE()函数可以用新字符串替换列中的换行符,而换行符可使用“char(13)”来表示,语法为“replace(字段名,char(13),'新字符串') ”。

方法:1、利用right函数,语法为“update 表名 set 指定字段 = right(指定字段, length(指定字段)-1)...”;2、利用substring函数,语法为“select substring(指定字段,2)..”。

mysql的msi与zip版本的区别:1、zip包含的安装程序是一种主动安装,而msi包含的是被installer所用的安装文件以提交请求的方式安装;2、zip是一种数据压缩和文档存储的文件格式,msi是微软格式的安装包。

转换方法:1、利用cast函数,语法“select * from 表名 order by cast(字段名 as SIGNED)”;2、利用“select * from 表名 order by CONVERT(字段名,SIGNED)”语句。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于MySQL复制技术的相关问题,包括了异步复制、半同步复制等等内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了mysql高级篇的一些问题,包括了索引是什么、索引底层实现等等问题,下面一起来看一下,希望对大家有帮助。

在mysql中,可以利用REGEXP运算符判断数据是否是数字类型,语法为“String REGEXP '[^0-9.]'”;该运算符是正则表达式的缩写,若数据字符中含有数字时,返回的结果是true,反之返回的结果是false。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。