.JDBC基本概念:
    java database Connectivity java数据库连接,java语言操作数据库
    本质:
        官方定义的一套操作所有关系型数据库的规则,即接口。
        各个数据库厂商实现这套接口,提供数据库驱动jar包。
        我们是以这套接口编程,真正执行的代码是驱动jar包中的实现类
.快速入门:
    步骤:
        .导入驱动jar包
        .注册驱动
        Class.
        .获取数据库连接对象 Connection
        .定义sql
        .获取执行sql语句的对象 Statement
        .执行sql,接收返回结果
        .处理结果
        .释放资源
.JDBC各个接口和类的详解:
    .DriverManager:驱动管理对象
        功能:
            .注册驱动:
                Class.forName("com.mysql.jdbc.Driver");
                mysql5之后驱动jar包可以省略注册驱动的步骤
            .获取数据库连接
                static Connection getConnection(String url, String user, String password)
                参数:
                    url:指定连接的路径
                        jdbc:mysql://ip地址(域名):端口号/数据库名称
                    user:用户名
                    password:密码
    .connection: 数据库连接对象
        .功能:
            .获取执行sql的对象
                Statement createStatement()
                PreparedStatement prepareStatement(String sql)
            .管理事务:
                开启事务:void setAutoCommit(boolean autoCommit):调用该方法设置参数为false,即开启事务
                提交事务:void commit()
                回滚事务:void rollback()
    .statement: 指定sql的对象
        .boolean execute(String sql):可以执行任意sql 了解
        .int executeUpdate(String sql):执行DML(insert update delete)语句、DDL(create alter drop)语句
        .ResultSet executeQuery(String sql):执行DML(insert update delete)语句、DDL(create alter drop)语句
            返回值:影响的行数
    .ResultSet:结果集对象
        .boolean next():游标向下移动一行
        .getXxx():获取数据  Xxx:数据类型
        .getXxx(参数):
            int:列的编号从1开始
            String:列名称
        注意:
            使用步骤:
                .游标向下移动一行
                .判断是否有数据 使用next的返回值判断
                .获取数据
    .PreparedStatement:执行sql的对象
        .SQL注入问题:在拼接sql时有一些sql特殊关键字参与拼接回造成安全性问题
            .输入用户名随意,输入密码:a' or 'a' = 'a
        .解决sql注入问题:使用PreparedStatement对象来解决
        .预编译的sql:参数使用?作为占位符
        .步骤:
            .写sql语句使用占位符
            .Connection.prepareStatement(String sql)
            .给?赋值:.setXxx(参数1,参数2)
                参数1:?的位置
                参数2:?的值
            .执行sql不需要参数

*/

import java.sql.*;

public class JDBC_Test01 {
    public static void main(String[] args) throws ClassNotFoundException, SQLException {
        .注册驱动
        Class.forName("com.mysql.jdbc.Driver");
        .获取数据库连接对象 Connection
        Connection connection /day01","root","ROOT");
        .定义sql
        String sql = "show tables";
        .获取执行sql语句的对象 Statement
        Statement statement = connection.createStatement();
        .执行sql,接收返回结果
        int count = statement.executeUpdate(sql);
        .处理结果
        System.out.println(count);
        .释放资源
        connection.close();

JDBC_入门及注入问题的更多相关文章

  1. 初级安全入门——XSS注入的原理与利用

    XSS的简单介绍 跨站脚本攻击(Cross Site Scripting),为不和层叠样式表(Cascading Style Sheets,CSS)的缩写混淆,故将跨站脚本攻击缩写为XSS.恶意攻击者 ...

  2. 初级安全入门——SQL注入的原理与利用

    工具简介 SQLMAP: 一个开放源码的渗透测试工具,它可以自动探测和利用SQL注入漏洞来接管数据库服务器.它配备了一个强大的探测引擎,为最终渗透测试人员提供很多强大的功能,可以拖库,可以访问底层的文 ...

  3. 基础Web漏洞-SQL注入入门(手工注入篇)

    一.什么是SQL注入  SQL是操作数据库数据的结构化查询语言,网页的应用数据和后台数据库中的数据进行交互时会采用SQL.而SQL注入是将Web页面的原URL.表单域或数据包输入的参数,修改拼接成SQ ...

  4. Spring入门-----------------属性注入和对象注入

    属性注入即通过setter方法注入bean的属性或依赖对象. 属性注入使用<property>元素,使用name属性指定bean的属性的名称,value属性或<value>子节 ...

  5. PHP代码审计入门(SQL注入漏洞挖掘基础)

    SQL注入漏洞 SQL注入经常出现在登陆页面.和获取HTTP头(user-agent/client-ip等).订单处理等地方,因为这几个地方是业务相对复杂的,登陆页面的注入现在来说大多数是发生在HTT ...

  6. CTF SSTI(服务器模板注入)

    目录 基础 一些姿势 1.config 2.self 3.[].() 3.url_for, g, request, namespace, lipsum, range, session, dict, g ...

  7. LDAP注入介绍

    LDAP注入介绍 一. 前言 前些日子在看 OWASP TOP 10 时看到了对LDAP注入攻击的介绍,对此产生了兴趣,在网上经过一番搜索之后找到了构成本文主要来源的资料,整理出来分享给大家. 二. ...

  8. 紧跟时代步伐,让我们拥抱MVC 3

    作为一个开发者,我们不希望技术很快的更新,这是因为我们还没有完全掌握原来技术的基础上,又要掌握新的技术,作为天天忙忙碌碌的程序员,我们不希望还要额外的时间来学习,尤其是当我们的年龄,逐渐的变大的时候, ...

  9. 4.JDBC编程

    01.JDBC_Java程序和MySQL的关系:     1).Java程序跟其它MySQL客户端一样,就是一个"客户端",用于"封装SQL语句"并发送给MyS ...

随机推荐

  1. 无法将 Ethernet0 连接到虚拟网络”VMnet0″ 详细信息可以在 vmware.log 文件中找到未能连接虚拟机Ethernet0

    在 vmware“编辑->虚拟网络设置”里面,点“恢复默认”可解决.  

  2. error C3867: “std::basic_string<char,std::char_traits<char>,std::allocator<char>>::c_str”: 函数调用缺少参数列表;请使用“&std::basic_string<char,std::char_traits<char>,std::allocator<char>>::c_str”创建指向成员的指针

    这个问题找了很多没有找到满意的答案.仔细看了一下,是使用了c_str的问题. 我直接把使用string.c_str的地方使用char*代替即解决问题.

  3. 通过MyEclipse操作数据库,执行sql语句使我们不用切换多个工具,直接工作,方便快捷

    通过MyEclipse操作数据库,执行sql语句使我们不用切换多个工具,直接工作,方便快捷.效果如下:     步骤1:通过MyEclipse中的window->show View->ot ...

  4. 十、 shell基础

    shell的表现形式: history -c 清空历史命令(清空缓存;默认:1000条) -w 将缓存中的历史命令保存到配置文件中 ~/.bash_history 永久保存历史命令(默认:1000条) ...

  5. 在vue中使用高德地图开发,以及AMap的引入?

    百度引入BMap ,一个import 即可,可AMap 却报AMap is not difined ? 1.首先在 externals: { "BMap": "BMap& ...

  6. web APP 开发之踩坑手记

    屏蔽输入框怪异的内阴影 -webkit-appearance:none 禁止自动识别电话和邮箱 <meta content="telephone=no" name=" ...

  7. JOOQ 入门--简介

    序言 新接触的项目中存在的大量的原生JDBC的代码,满屏幕都是PrepareStatement 和ResultSet, 以及各种关闭资源的语句. 所以有了用开源框架去重写的想法,然后就找到了JOOQ. ...

  8. Ubuntu下搭建NFS,并在开发板挂载

    ---恢复内容开始--- zai root huanjingxiachaozhuo $ su 一.搭建NFS 1.执行命令:sudo apt-get install nfs-kernel-server ...

  9. pandas--排序和排名

    排序 要对行或列索引进行排序,可使用sort_index方法,它将返回一个已排序的新对象: Series 1.对Series索引排序 obj=Series(range(4),index=['d','a ...

  10. ES6点点点运算符

    1. rest(可变)参数 * 用来取代arguments 但比arguments灵活,只能是最后部分形参参数 function add(...values) { let sum = ; for(va ...