用java连接mysql实现对表中的数据查找,插入,修改等功能,
JDBC操作MySQL数据库的步骤
1、准备MySQL数据库驱动包:mysql-connector-java-5.0.8-bin.jar,一个项目中只能存在一个版本的驱动包
a、复制该驱动包,粘贴到项目中
b、选中项目里的驱动包,右键-Build Path-Add to Build Path
2、在类里写代码加载驱:决定连接哪种数据库
a、Class.forName(\"com.mysql.jdbc.Driver\");
b、必须进行异常处理:ClassNotFoundException
3、连接数据库
a、Connection con=DriverManager.getConnection(\"连接字符串\", \"用户名\", \"密码\");
b、连接字符串格式固定,不同数据库,格式不同:jdbc:mysql://要连接的计算机名称:端口号/要连接的数据库名称
c、必须进行异常处理:SQLException
4、拼写要执行的sql语句,必须是可以在数据库中执行的
5、创建执行sql语句的对象
a、Statement stmt=con.createStatement();
b、注意:Statement必须来自于java.sql包中
6、执行sql语句
a、执行insert、update和delete语句:int row=stmt.executeUpdate(sql);返回影响行数
b、执行查询语句:ResultSet rs=stmt.executeQuery(sql);返回查询结果
c、执行任意sql语句(DDL、DCL、DML和DQL等)
7、对执行结果进行处理
a、执行更新语句:判断影响行数是否为0,0表示失败,非0表示成功
b、对查询结果进行处理:
1) 结果集需要先移动、后取值 :rs.next();int id=rs.getInt(1);
String name=rs.getString(\"loginName\");
2) 结果集有多条时,需要循环操作:
while(rs.next()){ System.out.println(rs.getInt(1)+\"\\t\"+rs.getString(2)+\"\\t\"+rs.getString(3)+\"\\t\"+rs.getString(4)+\"\\t\"+rs.getInt(5));
}
3) 不确定是否有查询结果时:if(rs.next()){说明有查询结果}else{没有查询结果}
4) 使用了聚合函数,一定有查询结果,查询结果是一行一列:
rs.next();
int result=rs.getInt(1);
注意:结果集取值时取出的时查询语句中包含的字段,与表中字段无关
9、关闭相关对象(先关闭结果集对象、在关闭执行语句对象,最后关闭连接对象)
例如:执行查询语句
Scanner input=new Scanner(System.in);
System.out.print(\"请输入登录名: \");
String name=input.next();
System.out.print(\"请输入密码: \");
String pass=input.next();
try {
Class.forName(\"com.mysql.jdbc.Driver\");
Connection con=DriverManager.getConnection(\"jdbc:mysql://localhost:3306/userdb\", \"root\", \"root\");
String sql=\"select COUNT(*) from UserInfo where loginName=\'\"+name+\"\' and loginPass=\'\"+pass+\"\'\";
Statement stmt=con.createStatement();
ResultSet rs=stmt.executeQuery(sql);
rs.next();
int result=rs.getInt(1);
if(result!=0){
System.out.println(\"登录成功!\");
}else{
System.out.println(\"用户名或密码错误,请重新登录!\");
}
rs.close();
stmt.close();
con.close();
} catch (ClassNotFoundException e) {
System.out.println(\"加载驱动错误:\"+e.getMessage());
} catch (SQLException e) {
System.out.println(\"数据库操作错误:\"+e.getMessage());
}
执行添加、修改和删除语句
try {
//加载驱动
Class.forName(\"com.mysql.jdbc.Driver\");
//连接数据库
Connection con=DriverManager.getConnection(\"jdbc:mysql://localhost:3306/userdb\", \"root\", \"root\");
//拼写要执行的sql语句
String sql=\"update UserInfo set loginPass=\'111\' where loginName=\'a\'\";
//String sql=\"insert UserInfo values(default,\'test\',\'test\')\";
//String sql=\"delete from UserInfo where loginName=\'a\'\";
//创建执行语句对象
Statement stmt=con.createStatement();
//执行
int row=stmt.executeUpdate(sql);
//处理结果
if(row==0){
System.out.println(\"修改失败!\");
}else{
System.out.println(\"修改成功!\");
}
//关闭
stmt.close();
con.close();
} catch (ClassNotFoundException e) {
System.out.println(\"驱动加载错误:\"+e.getMessage());
} catch (SQLException e) {
System.out.println(\"数据库操作错误:\"+e.getMessage());
}
mysql快速查询数据库中有多少条数据
今天主要复习了MySQL的一些简单语句,可总结:
mysql 统计 表的数量:SELECT COUNT(1) FROM information_schema.TABLES WHERE TABLE_SCHEMA = \'你的数据库\';
有时候需要查询MySQL数据库中各个表大小,该如何操作呢?
MySQL中有一个名为 information_schema 的数据库,在该库中有一个 TABLES 表,这个表主要字段分别是:
TABLE_SCHEMA : 数据库名
TABLE_NAME:表名
ENGINE:所使用的存储引擎
TABLES_ROWS:记录数
DATA_LENGTH:数据大小
INDEX_LENGTH:索引大小
use information_schema;
SELECT
TABLE_NAME,
(DATA_LENGTH/1024/1024) as DataM ,
(INDEX_LENGTH/1024/1024) as IndexM,
((DATA_LENGTH+INDEX_LENGTH)/1024/1024) as AllM,
TABLE_ROWS
FROM
TABLES
WHERE
TABLE_SCHEMA = \'你的数据库\';
MySQL的一些基础语句:
行是记录 列是字段
创建库
CREATE DATABASE [IF NOT EXISTS] 数据库名 [参数[ 参数] [ 参数]...];
参数:
CHARACTER SET 码表名
COLLATE 校对规则名, 详见文档10.10.1
显示库
SHOW DATABASES;
显示数据库创建语句
SHOW CREATE DATABASE 数据库名;
修改库
ALTER DATABASE 数据库名[ 参数[ 参数][ 参数]...];
注意: 不能改数据库的名字
删除库
DROP DATABASE [IF EXISTS] 数据库名;
操作表之前使用需要先确定使用哪个数据库
USE 数据库名
创建表
CREATE TABLE 表名(列名 类型[,列名 类型][,列名 类型]...);
查看所有表
SHOW TABLES;
查看表的创建语句
SHOW CREATE TABLE 表名;
显示表结构
DESC 表名;
修改表名
RENAME TABLE 原表名 TO 新表名;
修改字符集
ALTER TABLE 表名 CHARACTER SET 字符集名;
删除表
DROP TABLE 表名;
追加列
ALTER TABLE 表名 ADD 列名 类型[,列名 类型][,列名 类型]...;
修改列类型
ALTER TABLE 表名 MODIFY 列名 类型[,列名 类型][,列名 类型]...;
修改列
ALTER TABLE 表名 CHANGE COLUMN 原列名 新列名 类型;
删除列
ALTER TABLE 表名 DROP 列名;
插入语法:
INSERT INTO 表名[(列名[,列名]...)] VALUES(值[,值]...);
注意事项:
插入值类型必须与对应列的数据类型一致
数据不能超出长度
插入值得为之必须与列名顺序一致
字符和日期数据要放在单引号中
插入空值使用null
如果不指定插入哪一列, 就是插入所有列
中文数据
由于默认码表是utf8, 而cmd.exe的码表是gbk, 在插入中文数据的时候会报错, 所以我们需要修改客户端码表
先查看系统变量: SHOW VARIABLES LIKE \'character%\';
修改客户端码表: SET character_set_client=gbk;
修改输出数据的码表: SET character_set_results=gbk;
修改语法
UPDATE 表名 SET 列名=值[,列名=值]...[WHERE 条件语句];
注意事项
WHERE子句选择满足条件的行进行更新, 如果不写, 则更新所有行
删除语法
DELETE FROM 表名 [where 条件语句]
注意事项
如果不加where子句, 将删除表中所有记录
delete只能用作删除行, 不能删除某一列的值, 需要用update
在delete和update的时候需要注意表与表之间的关联关系
删除表中所有数据可以使用: TRANCATE 表名, 这种方式会删除旧表重新创建, 在数据较多的时候使用
备份数据库
输入quit退出mysql, 在cmd.exe中输入:
mysqldump –u用户名 –p密码 数据库名 文件名
恢复数据库
进入mysql.exe之后, 使用数据库之后
source 文件名
操作数据(查询)
DISTINCT语法
SELECT [DISTINCT] 列名[, 列名]... FROM 表名
注意事项
*可以替代列名, 表示所有列, 但是通常我们为了提高代码的可读性, 不使用*
DISTINCT为过滤重复记录
如果DISTINCT后面跟多列, 是过滤掉多列合并之后的重复
列名表达式——语法
SELECT 列名|表达式[,列名|表达式]... FROM 表名
注意事项
表达式只是显示时起作用, 不会改变数据库中的值
AS——
SELECT 列名 AS 别名 FROM 表名
注意事项
起别名时AS可以省略
不会改变数据库中的值
WHERE——
语法
SELECT 列名 FROM 表名 [WHERE 条件语句]
WHERE子句中的运算符
比较运算符
, , =, =, =,
注意不等于和Java中不同, 是
BETWEEN ... AND ...
某一区间内的值, 从 ... 到 ...
IN(列表)
在列表之中, 例: in(1,2,3) 代表1或2或3
LIKE(表达式)
模糊查询, %代表多个字符, _代表单个字符
IS NULL
判断是否为NULL
逻辑运算符
AND
与, 两边都为TRUE结果为TRUE
OR ||
或, 一边为TRUE结果就为TRUE
NOT !
非, 将表达式结果取反
ORDER BY——
语法
SELECT 列名 FROM 表名 ORDER BY 列名 ASC|DESC;
注意事项
ORDER BY 指定排序的列名可以是表中的列名, 也可以是SELECT语句后面起的别名
ASC为升序, DESC为降序
ORDER BY应在查询语句的结尾
COUNT函数——
语法
SELECT COUNT(*)|COUNT(列名) from 表名 [WHERE 条件语句]
注意事项
COUNT(列名)的方式是统计指定列中有多少条记录, 不包括值为NULL的
COUNT(*)则是统计表中有多少条数据
COUNT(DISTINCT 列名) 统计不重复的记录数
如果加上WHERE子句, 则是统计满足条件的记录
mysql如何进入数据库查看所有表
1.查看数据库,选中使用数据库,并查看数据库表,具体操作命令如下:
show databases;
use student;
show tables;
2.选择student数据库中的一张表stu_score,查看数据库表数据,并利用explain分析数据库表,如下图所示:
select * from stu_score;
explain select * from stu_score;
3.查看数据库使用索引的情况,使用命令:
show status like \'Handler_read%\';
4.用于分析和存储表的关键字,分析的结果可以得到精准的信息,利用命令analyze,
analyze table stu_score;
5.检查数据库表stu_score,检查表是否有错误,利用命令:
check table stu_score;
6.优化数据库表,利用命令:
optimize table stu_score;
扩展资料:
可以使用命令行工具管理 MySQL 数据库(命令 mysql 和 mysqladmin),也可以从 MySQL 的网站下载图形管理工具 MySQL Administrator, MySQL Query Browser 和 MySQL Workbench。
phpMyAdmin是由 php 写成的 MySQ L资料库系统管理程程序,让管理者可用 Web 界面管理 MySQL 资料库。
phpMyBackupPro也是由 PHP 写成的,可以透过 Web 界面创建和管理数据库。它可以创建伪 cronjobs,可以用来自动在某个时间或周期备份 MySQL 数据库。
另外,还有其他的 GUI 管理工具,例如 mysql-front 以及 ems mysql manager, navicat等等。
Mysql Workbench查询mysql数据库方法
Mysql
Workbench是一款开源的数据库客户端,在IT行业这款开源的软件也是相当有名气的,很多使用musql的同仁都喜欢使用这款客户端工具。今天小编就跟大家一起去看看这款工具使用起来怎么样吧。
首先小编还是先从最开始说起,通过点击电脑开始→选择Mysql
Workbench,点击启动这个应用程序,当然看官也可以选择通过点击桌面快捷方式进入程序
通过前面配置的mysql
数据库链接,进行连接到mysql控制台,如下图小编选择已经配置好的链接进入到mysql数据库控制台
进入到数据库控制台后,在界面左侧下方显示的一个石油桶类似的图标旁边显示了数据库的数据库名。
鼠标移动到数据库上方,然后点击右键,可以看到一些针对数据库的常用操作。如下图
通过点击数据库名称旁边的展开按钮,可以看到table一个二级菜单,点击这个table,就可以展开对应数据库下方的所有数据表,如下图
在展开的数据表上方点击鼠标右键,可以针对数据表做的一些操作,如下图,小编选择第一个select
rows
limit
1000,查询出这个表格中的1000条数据。
您可能感兴趣的文章:mysql中workbench实例详解centOS下mysql
workbench安装配置教程Workbench通过远程访问mysql数据库的方法详解Ubuntu下mysql与mysql
workbench安装教程在Ubuntu
16.10安装mysql
workbench报未安装软件包
libpng12-0错误的解决方法MySQL
Workbench的使用方法(图文)解决MySQL
Workbench
gnome-keyring-daemon错误的方法分享MYSQL
ZIP免安装版配置步骤及图形化管理工具mysql-workbenchMySQL
WorkBench管理操作MySQL教程如何用workbench导出mysql数据库关系图
dos命令行怎么查询mysql数据库
mysql数据的查询是通过sql语句来实现的,常用的查询操作如下:
1、连接数据库
mysql -u 用户名 -p 用户密码
说明:可以在命令中直接接入密码,也可以不加入密码。
2、查看所有数据库
show databases;
3、选择数据库
use databasename;
3、查看该数据库下所有表
show tables;
4、查看表的区段
describe 表名;
5、查询表数据
select 字段名 from 表名;
mysql数据库,多个表的查询操作
select a.id,b.bd,c.cd from a left join b on a.bd=b.id left join c on a.cd=c.id