MySql频繁查询、插入数据
当我们需要频繁地从数据库查询、插入数据时,可以将这些数据库操作汇集写到同一个类里,作为工具类直接调用.
将数据库的具体信息保存在.properties文件中,用log4j作为日志记录
MySql.java代码如下:
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import org.apache.log4j.Level;
import org.apache.log4j.Logger;
public class Mysql {
private Connection conn;
private Statement smt;
static Logger logger = Logger.getLogger(Mysql.class.getName());
//加载数据库驱动
static {
try {
Class.forName("com.mysql.jdbc.Driver").newInstance();
} catch (Exception e) {
logger.log(Level.ERROR, "Mysql:" + e.getMessage());
}
}
//连接数据库
public Mysql(String url, String user, String pwd) throws Exception {
conn = DriverManager.getConnection(url, user,pwd);
smt= conn.createStatement();
}
//插入数据
public ResultSet executeQuery(String sql) throws Exception {
ResultSet rs = null;
try {
rs = smt.executeQuery(sql);
} catch (SQLException e) {
logger.log(Level.ERROR, sql+"\n" + e.getMessage());
}
return rs;
}
//查询数据
public void executeInsert(String sql) throws Exception {
smt.executeUpdate(sql);
conn.commit();
}
//关闭数据库
public void close() throws Exception {
smt.close();
conn.close();
}
}
数据库信息如下:
db.properties
url=jdbc:mysql://10.255.245.6:3306/abc user=abc password=123
MySqlTest.java,将MySql作为工具类使用,进行数据库操作
import org.apache.log4j.Level;
import org.apache.log4j.Logger;
import java.io.IOException;
import java.io.InputStream;
import java.sql.ResultSet;
import java.util.Properties;
public class MySqlTest {
private static String url;
private static String user;
private static String password;
private static Mysql mysql;
static Logger logger = Logger.getLogger(MySqlTest.class.getName());
private static Properties prop = new Properties();
static {
InputStream is =MySqlTest.class.getClassLoader().getResourceAsStream("db.properties");
try {
prop.load(is);
} catch (IOException e) {
logger.log(Level.ERROR, "db.properties:" + e.getMessage());
}
}
//初始化MySql
public static void initialMySql() throws Exception{
url = prop.getProperty("url");
user = prop.getProperty("user");
password = prop.getProperty("password");
mysql = new Mysql(url, user, password);
}
//查询mysql数据
public static void queryData(String sql) throws Exception{
ResultSet rs=mysql.executeQuery(sql);
while (rs.next()) {
String str=rs.getString(1);
System.out.println(str+" ");
}
rs.close(); mysql.close();
}
//插入数据 public static void insertData(String sql) throws Exception{ mysql.executeInsert(sql); mysql.close(); }
}
MySql频繁查询、插入数据的更多相关文章
- mysql数据库中插入数据INSERT INTO SET的优势
往mysql数据库中插入数据.以前常用 INSERT INTO 表名 (列名1,列名2…) VALUES(列值1,列值2); 如果在PHP程序中,就会写成如下示例(往商品库里增加商品) $sql = ...
- jmeter连接mysql数据库批量插入数据
前提工作: 1.在jmeter官网下载jmeter包(官网地址:https://jmeter.apache.org/).此外还需下载mysql驱动包,如:mysql-connector-java-5. ...
- mysql:insert插入数据过慢如何解决,设置innodb_flush_log_at_trx_commit为0就能解决
问题: 最近在做性能测试,造数据,发现insert好慢,只有几十条每秒,很奇怪,最后再网上找到了原因. 网文如下: MY SQL insert 速度过慢 最近在用MySQL做存储,测试中发现插入数据太 ...
- mysql使用存储过程插入数据后,参数为中文的为?或乱码
最近了解了一下mysql存储过程,之前版本的mysql不支持存储过程,5.0版本后就可以支持存储过程的使用:恰好笔者下载使用版本为5.6.20: 做了一个给表插入数据的简单存储过程,发现打开表后汉字全 ...
- 向mysql中批量插入数据的性能分析
MYSQL批量插入数据库实现语句性能分析 假定我们的表结构如下 代码如下 CREATE TABLE example (example_id INT NOT NULL,name VARCHAR( 5 ...
- MYSQL 4种插入数据的方式比较
4种插入数据的方式 第一种:insert into insert into是最常用的插入数据的方式,可以单条插入,也可以多条,还可以指定从其他表中select然后插入. 详细可以参考:insert语法 ...
- 关于PHP连接上MySQL但不能插入数据
出现这种情况,有三种可能 1.SQL语句有问题 insert into table_name(field1,field2...) values(value1,value2...); 先在MySQL中粘 ...
- 使用存储过程在mysql中批量插入数据
一.在mysql数据库中创建一张表test DROP TABLE IF EXISTS `test`; CREATE TABLE `test` ( `id` INT (11), `name` VARCH ...
- MySQL如何快速插入数据
前言: 日常学习和工作中,经常会遇到导数据的需求.比如数据迁移.数据恢复.新建从库等,这些操作可能都会涉及大量数据的导入.有时候导入进度慢,电脑风扇狂转真的很让人崩溃,其实有些小技巧是可以让导入更快速 ...
随机推荐
- bzoj 4929: 第三题
Description 给定n,b,c,d,e以及A0,A1,···,An−1,定义 xk=b×c^4k+d×c^2k+e f(x)=Sigma(Aix^i),0<=i<=n-1 请你求出 ...
- linux下maven项目clean失败
今天在linux下创建了一个项目自动化发布的脚本,在执行到 mvn clean package -Dmaven.test.skip=true 的时候,项目clean失败 查下下度娘,windows下导 ...
- Java中的yield关键字的简单讲解
Thread.yield()方法作用是:暂停当前正在执行的线程对象,并执行其他线程. yield()应该做的是让当前运行线程回到可运行状态,以允许具有相同优先级的其他线程获得运行机会.因此,使用yie ...
- Mac parallels desktop安装windows,linux
前言 这款软件你就看作是虚拟机vm,如果你要安装win10系统,请下载ios镜像文件 下载准备工作 Parallels Desktop 13 破解版本 联系站长所要 win10 iso镜像文件 ...
- keras输出中间层结果,某一层的权重、偏置
转载:https://blog.csdn.net/hahajinbu/article/details/77982721 from keras.models import Sequential,Mode ...
- Spark wordcount开发并提交到集群运行
使用的ide是eclipse package com.luogankun.spark.base import org.apache.spark.SparkConf import org.apache. ...
- PHP mysqli_autocommit() 函数
定义和用法 mysqli_autocommit() 函数开启或关闭自动提交数据库修改. 提示:请查看 mysqli_commit() 函数,用于提交指定数据库连接的当前事务.请查看 mysqli_ro ...
- centos中YUM安装后文件的常见路径
1 php的相关 1)ini的文件 /etc/php.ini 2 apache相关 1) conf的文件 /etc/httpd/conf 2)错误日志 /etc/httpd/logs 3)扩展文 ...
- Sqoop增量导入
Argument Description --check-column (col) Specifies the column to be examined when determining which ...
- 1.获取服务器IP、端口等
比如,页面内部有一个连接,完整的路径应该是 http://192.168.0.1:8080/myblog/authen/login.do 其中http://server/是服务器的基本路径,myblo ...