JDBC之PreparedStatement的理解

前言:怀着疑惑和痛苦的心情写下这篇文章,其中疑惑之一是预编译对象,会把编译之后的整个语句保存在对象中,如果保存保存在哪里呢?
注:本文以mysql数据库为基础展开

一、基础知识

1、SQL语句在数据库中的执行过程

一条SQL语句从客户端(如: java 程序、navicat工具、cmd命令行)发送到数据库管理系统后,要经历以下过程:

  1. 词法和语义的解析
  2. 优化SQL语句,制定执行计划
  3. 执行并返回结果
2、预编译语句
     形如 select * from user where id = 1,这种普通语句叫做 Immediate Statement,执行时要经历完整的SQL执行过程

     形如select * from user where id = ?, 使用占位符代替语句中字段的值,这种语句叫做Prepared Statement,执行时,首先要进行预编译,之后每次执行都省去了解析优化等过程。

     预编译语句适用场景:一条SQL语句需要反复执行多次并且只有字段的值可能存在改变(如query的where子句值不同,update的set子句值不同,insert的values值不同)

二、MySQ数据库的预编译功能

1、开启数据库日志功能

为了更好的了解SQL语句的执行,需要开启mysql的查询日志功能。本文通过设置mysql全局变量方式开启,mysql服务重启后配置失效。


第一步:通过命令行,进入mysql客户端,输入命令: show variables like "general_%"; general_log = OFF 表明日志功能没有开启。

在这里插入图片描述


第二步:开启日志功能,输入命令: set global general_log = "ON";                                            修改保存日志的文件(非必要操作),输入命令: set global general_log_file = "D:\\mysql\\data\query01.log";
第三步: 查看是否开启成功,输入命令 show variables like "general_%";

在这里插入图片描述

2、执行mysql预编译命令

在执行相关操作前,需要创建一张表,作为操作对象。建表语句如下:

create table user(
  id int auto_increment primary key,
  username varchar(50),
  passw
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

明月几时有666

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值