package cn.zhouzhou;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement; import com.mysql.jdbc.PreparedStatement; /*一、接口的概念和想相关静态方法?--------建议自己去查手册!
*
* 1.connection?
* 接口
* 与特定数据库的连接(会话)。 执行SQL语句并在连接的上下文中返回结果。
该信息是用getMetaData方法获得的。 *2. Driver?
* 每个驱动程序类必须实现的接口。
* 每个驱动程序都应该提供一个实现Driver接口的类。
*
*5.DriverManager?
* 用于管理一组JDBC驱动程序的基本服务。
* DriverManager将尝试加载尽可能多的驱动程序,然后对于任何给定的连接请求,它会依次要求每个驱动程序尝试连接到目标URL。 3. Connection?
* 与特定数据库的连接(会话)。 执行SQL语句并在连接的上下文中返回结果。
*
4.getConnection?
* 尝试建立与给定数据库URL的连接。DriverManager的静态方法 返回值类型 Connection
*
*6.Statement?
* 创建一个 Statement对象,将产生 ResultSet对象具有给定类型,并发性和可保存性。
* 返回值类型是statement;
* execute方法查找名称与 methodName属性相同的方法,并调用目标方法。
*
*7.ResultSet?
* 表示数据库结果集的数据表,通常通过执行查询数据库的语句生成。
* ResultSet对象保持一个光标指向其当前的数据行。
* getInt?
* 将此 ResultSet对象的当前行中指定列的值作为Java编程语言中的 Array对象检索。
*
*8.设置SQL语句的执行平台?
* Connection con= DriverManager.getConnection(url,use,password)
* Statement star=con.createStatemtn();
*
*9.对数据库的操作?
* 1.int ------------->适用于 增删改! insert update delete
* int i= star.executeUpdate("");
*
* 2.String -------------用于SQL查询语句 select
* String s="";
* ResultSet rs= star.excuteQuery(s); 执行SQL中的select查询
* while(rs.next()){----------------------->处理结果集,并获取每列数据。
* System.out.println(rs.getInt("id")+""+rs.getString("name")+" "+rs.getDouble("price")); *}
*10.结束资源?
*
*
*二、SQL注入攻击简单的案
* 换个接口,解决风险!preparestatement
* 使用Statement接口 容易容易被注入攻击。
* Statement接口实现类,作用执行SQL语句,返回结果集
* 有一个子接口PreparedStatement (SQL预编译存储,多次高效的执行SQL)
*
* 记着!使用PrepareStatement接口
* 方法?
* PreparedStatement xx=con.prepareStatement(String sql)
*
*
*
*/
public class JdbcDmo {
public static void main(String[] args) throws Exception {
// run(); //数据库的注册、连接、设置语句执行平台、执行SQL语句、处理结果、结束资源。
show(); } private static void show() throws Exception {
Class.forName("com.mysql.jdbc.Driver"); String url="jdbc:mysql://localhost:3306/qy66";
String use="root";
String password="root";
Connection con01=DriverManager.getConnection(url, use, password); // Statement star01=con01.createStatement(); 之前的statement接口 String s="select * from shop"; java.sql.PreparedStatement star01=con01.prepareStatement(s); //换个接口preparestatement ResultSet rs=star01.executeQuery(s);
while (rs.next()) {
System.out.println(rs.getInt(1)+" "+rs.getString(2));
}
rs.close();
star01.close();
con01.close(); } private static void run() throws Exception{
Class.forName("com.mysql.jdbc.Driver"); //1.注册 5.0版本后可以省略不写 String url="jdbc:mysql://localhost:3306/qy66"; //定义各自的 连接地址 用户名 密码
String use="root";
String password="root"; Connection con=DriverManager.getConnection(url, use, password); //2.连接数据库
System.out.println(con); //3.打印的是地址! Statement a1=con.createStatement();
System.out.println(a1); //获得语句执行平台 String a3="select * from shop"; //执行SQL中的select查询 【注意String】查询sql语句 ResultSet rs= a1.executeQuery(a3);
//while 可以获取数据库表格中的每一列数据!
while (rs.next()) {
System.out.println(rs.getInt("id")+""+rs.getString("name")+" "+rs.getDouble("price"));
} // insert update delete
int a2=a1.executeUpdate("insert into shop(id,name,price)values (101,'003',5000)");//执行sql语句 int 适用于增删改
System.out.println(a2); con.close();
a1.close();
rs.close(); } }

jdbc 接口的用法 Statement和PreparedStatement的区别!的更多相关文章

  1. JDBC中的Statement和PreparedStatement的区别

    JDBC中的Statement和PreparedStatement的区别  

  2. Statement与PreparedStatement的区别

    Statement与PreparedStatement的区别   PreparedStatement预编译SQL语句,性能好. PreparedStatement无序拼接SQL语句,编程更简单. Pr ...

  3. Statement和PreparedStatement的区别; 什么是SQL注入,怎么防止SQL注入?

    问题一:Statement和PreparedStatement的区别 先来说说,什么是java中的Statement:Statement是java执行数据库操作的一个重要方法,用于在已经建立数据库连接 ...

  4. Statement和PreparedStatement的区别; 什么是SQL注入,怎么防止SQL注入? (转)

    问题一:Statement和PreparedStatement的区别 先来说说,什么是java中的Statement:Statement是java执行数据库操作的一个重要方法,用于在已经建立数据库连接 ...

  5. 浅析Statement和PreparedStatement的区别

    当我们使用java程序来操作sql server时会使用到Statement和PreparedStatement,俩者都可以用于把sql语句从java程序中发送到指定数据库,并执行sql语句.那么如何 ...

  6. JDBC与Statement和PreparedStatement的区别

    一.先来说说,什么是java中的Statement:Statement是java执行数据库操作的一个重要方法,用于在已经建立数据库连接的基础上,向数据库发送要执行的SQL语句.具体步骤: 1.首先导入 ...

  7. [转] JDBC中的Statement和PreparedStatement的区别

    以Oracle为例吧 Statement为一条Sql语句生成执行计划,如果要执行两条sql语句select colume from table where colume=1;select colume ...

  8. 【Java编程】建立一个简单的JDBC连接-Drivers, Connection, Statement and PreparedStatement

    本blog提供了一个简单的通过JDBC驱动建立JDBC连接例程.并分别通过Statement和PreparedStatement实现对数据库的查询. 在下一篇blog中将重点比較Statement与P ...

  9. JDBC中的Statement 和PreparedStatement的区别?

    PreparedStatement是预编译的SQL语句,效率高于Statement. PreparedStatement支持操作符,相对于Statement更加灵活. PreparedStatemen ...

随机推荐

  1. C语言数组求长度

    1.创建数组 ,,,,};/*创建一个int型数组,数组的长度为5*/ 2.利用sizeof求一维数组长度 int len; len = sizeof(a)/sizeof(int); Δ以上求数组长度 ...

  2. Java多线程(六)——线程让步

    一.yield()介绍 yield()的作用是让步.它能让当前线程由“运行状态”进入到“就绪状态”,从而让其它具有相同优先级的等待线程获取执行权:但是,并不能保证在当前线程调用yield()之后,其它 ...

  3. 【原创】Mysql中select的正确姿势

    引言 大家在开发中,还有很多童鞋在写查询语句的时候,习惯写下面这种不规范sql select * from table 而不写成下面的这种规范方式 select col1,col2,...,coln ...

  4. Git 使用vi或vim命令打开、关闭、保存文件

    1 vi & vim 有两种工作模式: (1)命令模式:接受.执行 vi & vim 操作命令的模式,打开文件后的默认模式: (2)编辑模式:对打开的文件内容进行 增.删.改 操作模式 ...

  5. Windows Community Toolkit 3.0 - Gaze Interaction

    概述 Gaze Input & Tracking - 也就是视觉输入和跟踪,是一种和鼠标/触摸屏输入非常不一样的交互方式,利用人类眼球的识别和眼球方向角度的跟踪,来判断人眼的目标和意图,从而非 ...

  6. 使用 OpenSSL 创建私有 CA:1 根证书

    OpenSSL 创建私有 CA 三部曲:使用 OpenSSL 创建私有 CA:1 根证书使用 OpenSSL 创建私有 CA:2 中间证书使用 OpenSSL 创建私有 CA:3 用户证书 OpenS ...

  7. P2P平台介绍

    https://www.ludou.org/tutengdai.html https://www.tutengdai.com/register?invite_code=9991300

  8. hibernate坑边闲话

    使用hibernate各种各样的坑 Remember that ordinal parameters are 1-based node to traverse cannot be null 这两个错误 ...

  9. Python学习第十六篇——异常处理

    在实际中,很多时候时候,我们并不能保证我们所写的程序是完美的.比如我们程序的本意是:用户在输入框内输入数字,并进行后续数学运算,即使我们提醒了用户需要输入数字而不是文本,但是有时会无意或者恶意输入字符 ...

  10. 消息队列queue

    一.queue 在多线程编程中,程序的解耦往往是一个麻烦的问题,以及在socket网络编程中也会有这样的问题.recv 和send之间,如果服务端有消息,问题需要发送给客户端,而那边的recv 被主程 ...