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如何快速插入数据
前言: 日常学习和工作中,经常会遇到导数据的需求.比如数据迁移.数据恢复.新建从库等,这些操作可能都会涉及大量数据的导入.有时候导入进度慢,电脑风扇狂转真的很让人崩溃,其实有些小技巧是可以让导入更快速 ...
随机推荐
- 【Spring实战-3】Spring整合Hibernate、Struts
作者:ssslinppp 1. 摘要 版本: Spring4.0.4:Hibernate4.3.5:struts2.3.16: 主要介绍了如下内容: 项目结构的规划: Spring下整合Hi ...
- JavaScript之图片操作3
在页面布局中,常常会用到九宫格布局,如下图所示: 本次我们就以九宫格为基础进行图片的布局操作,首先我们以上面的图片的为例,假设每个格子的大小都相同,将每一个格子相对其父元素进行定位,这样,我们只需要控 ...
- Linux 期中架构 inotify
全网备份数据同步方案 备份网站内部人员信息 不能解决外部(人员)上传数据的备份 定时任务最短执行的周期为一分钟,采用定时任务方式,有时可能造成一分钟内的数据丢失 因此对于重要数据需要采用实时同步的方 ...
- apache 服务器在ubuntu上图片无法显示解决
很简单的一段代码实例: <!DOCTYPE html> <html> <body> <h2>Welcome here!</h2> <i ...
- dbms_xplan之display_cursor函数的使用
DBMS_XPLAN包中display_cursor函数不同于display函数,display_cursor用于显示SQL语句的真实的执行计划,在大多数情况下,显示真实的执行计划有助于更好的分析SQ ...
- ACM MM | 中山大学等提出HSE:基于层次语义嵌入模型的精细化物体分类
细粒度识别一般需要模型识别非常精细的子类别,它基本上就是同时使用图像全局信息和局部信息的分类任务.在本论文中,研究者们提出了一种新型层次语义框架,其自顶向下地由全局图像关注局部特征或更具判别性的区域. ...
- VFS文件系统结构分析
VFS是Linux非常核心的一个概念,linux下的大部分操作都要用到VFS的相关功能.这里从使用者的角度,对VFS进行了简单说明.使用者不但需要知道Linux下有哪些文件操作的函数,还需要对VFS的 ...
- Redis如何存储对象与集合示例详解
前言 大家都知道在项目中,缓存以及mq消息队列可以说是不可或缺的2个重要技术.前者主要是为了减轻数据库压力,大幅度提升性能.后者主要是为了提高用户的体验度,我理解的是再后端做的一个ajax请求(异 ...
- mac 安装 nginx
我是用root用户装的 1.先安装PCRE库 可以在这里下载最新版,我这里使用的是8.33的版本然后在终端执行下面的命令. cd ~/Download tar xvzf pcre-8.33.tar.g ...
- Spring MVC 学习笔记1 - First Helloworld by Eclipse【& - java web 开发Tips集锦】
Spring MVC 学习笔记1 - First Helloworld by Eclipse reference:http://www.gontu.org 1. 下载 Spring freamwork ...