MYSQL简单命令

本贴最后更新于 3430 天前,其中的信息可能已经沧海桑田

常用 mysql 操作指令:

  1. 连接:mysql -u用户名 -p密码
  2. 退出:mysql>exit;
  3. 建数据库:mysql>create database ???;
  4. 显示数据库:mysql>show databases;//(-s)
  5. 删除数据库:mysql>drop database ???;
  6. 连接数据库:mysql>use ???;
  7. 创建数据表:mysql>create table ???(字段名 类型,字段名 类型);
  8. 删除表:mysql>drop table ???;
  9. 表插入数据:mysql>insert into 表名 value(?,?,...);//与建表元素个数相同,类型相符
  10. 表查数据:mysql>select ??? from 表名 where ??; mysql>select * from 表名;
  11. 表查前几行数据:mysql>select * from 表名 order by id limit 0,2;
  12. 删除表中数据:mysql>delete from 表名 where ???;
  13. 修改表中数据:mysql>update 表名 set name="???" where id=1?

如若以上内容不够用,可以参考这里

在实际的 JAVA WEB 中,就应当把数据库的驱动,连接,用户名和密码写在配置文件中。这样才便于维护。

以 Properties 读取配置文件:

java.properties:
driver=com.mysql.jdbc,Driver
url=jdbc:mysql://localhost:3306/test
user=root
password=5938

引入:

import java.io.InputStream;
import java.util.Properties;

读取操作:

static{
Properties prop	= new Properties();
InputStream in = 类名.class.getClassLoader().getResourceAsStream("jdbc.properties");
try{
    prop.load(in);
} catch(IOException e){
    e.printStackTrace();
}

driver=prop.getProperty("driver");
url=prop.getProperty("url");
user=prop.getProperty("user");
passwood=prop.getProperty("password");
}

完整的链接程序如下:

package	ppj.demo01.jdbc;

import java.io.InputStream;
import java.util.Properties;

import java.io.IOException;  
 
import java.sql.Connection;  
import java.sql.DriverManager;	
import java.sql.ResultSet;  
import java.sql.SQLException;  
import java.sql.Statement;  

/**
 * test	to connection sql
 * 单线程链接
 * @author pengpj
 *
 */
public class JDBCConnectionTest01 {
	/**
	 * 数据库连接设置
	 * driver 数据库驱动
	 * url 数据库链接字符
	 * user	用户名
	 * password 密码
	 */
	public static String driver=null;//"com.mysql.jdbc.Driver";
	public static String url = null;//"jdbc:mysql://localhost:3306/test";
	public static String user = null;//"root";
	public static String password =	null;//"5938";
	/**
	 * 在加载类时,将jdbc链接数据库的信息获取
	 * 获取途径:jdbc.properties
	 */
	 static	{
		Properties prop	= new Properties();
		InputStream in = JDBCConnectionTest01.class.getClassLoader().getResourceAsStream("jdbc.properties");
		try{
			prop.load(in);
		}catch(	IOException e){
			e.printStackTrace();
		}
		driver = prop.getProperty("driver");
		url = prop.getProperty("url");
		user = prop.getProperty("user");
		password = prop.getProperty("password");
	}
	/*
	 * 加载驱动
	 */
	{
		try{
			Class.forName(driver);
		}catch(ClassNotFoundException e){
			System.out.println("链接失败!\nnot found the exception");
			e.printStackTrace();
		}
	}
	/*
	 * 获取链接
	 */
	public static Connection getConne(){
		Connection conn	= null;
		try{
			conn = DriverManager.getConnection(url,	user, password);
		}catch(SQLException e){
			e.printStackTrace();
		}
		return conn;
	}
	/*
	 * 关闭结果集
	 */
	public static void close(ResultSet rs){
		if(null!=rs){
			try{
				rs.close();
			}catch(SQLException e){
				e.printStackTrace();
			}
		}
	}
	/*
	 * 关闭封装SQL命令的对象
	 */
	public static void close(Statement stmt){
		if(null!=stmt){
			try{
				stmt.close();
			}catch(SQLException e){
				e.printStackTrace();
			}
		}
	}
	/*
	 * 关闭链接
	 */
	public static void close(Connection conn){
		if(null!=conn){
			try{
				conn.close();
			}catch(SQLException e){
				e.printStackTrace();
			}
		}
	}
}

测试类如下:

package	ppj.demo01;

import ppj.demo01.jdbc.JDBCConnectionTest01;

import static org.junit.Assert.*;
import org.junit.Test;

import java.sql.Connection;  
import java.sql.ResultSet;  
import java.sql.Statement;  

public class testJDBCConnectionTest01 {
	@Test
	public void testGetConne() throws Exception{
		Connection conn	= null;
		Statement stmt = null;
		ResultSet rs = null;
		String sqlstr =	"select	* from user";
		try{
			conn = JDBCConnectionTest01.getConne();
			stmt = conn.createStatement();
			rs = stmt.executeQuery(sqlstr);
			while(rs.next()){
				int id = rs.getInt("id");
				String userName	= rs.getString("userName");
				String addr = rs.getString("addr");
				System.out.println("id:"+id+" userName:"+userName+" address:"+addr);
			}
		}catch(Exception e){
			
		}finally{
			JDBCConnectionTest01.close(conn);
			JDBCConnectionTest01.close(rs);
			JDBCConnectionTest01.close(stmt);
		}
		assertNotEquals("false",JDBCConnectionTest01.getConne(),JDBCConnectionTest01.getConne());
	}
}

注:

在数据库中已经建立有库 test 与表 user,所以可以在程序中直接链接调用而不用再建表。

  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    692 引用 • 535 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • CodeMirror
    1 引用 • 2 回帖 • 129 关注
  • Git

    Git 是 Linux Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

    209 引用 • 358 回帖
  • OpenShift

    红帽提供的 PaaS 云,支持多种编程语言,为开发人员提供了更为灵活的框架、存储选择。

    14 引用 • 20 回帖 • 632 关注
  • HHKB

    HHKB 是富士通的 Happy Hacking 系列电容键盘。电容键盘即无接点静电电容式键盘(Capacitive Keyboard)。

    5 引用 • 74 回帖 • 478 关注
  • Tomcat

    Tomcat 最早是由 Sun Microsystems 开发的一个 Servlet 容器,在 1999 年被捐献给 ASF(Apache Software Foundation),隶属于 Jakarta 项目,现在已经独立为一个顶级项目。Tomcat 主要实现了 JavaEE 中的 Servlet、JSP 规范,同时也提供 HTTP 服务,是市场上非常流行的 Java Web 容器。

    162 引用 • 529 回帖
  • 资讯

    资讯是用户因为及时地获得它并利用它而能够在相对短的时间内给自己带来价值的信息,资讯有时效性和地域性。

    55 引用 • 85 回帖 • 1 关注
  • DevOps

    DevOps(Development 和 Operations 的组合词)是一组过程、方法与系统的统称,用于促进开发(应用程序/软件工程)、技术运营和质量保障(QA)部门之间的沟通、协作与整合。

    51 引用 • 25 回帖
  • CongSec

    本标签主要用于分享网络空间安全专业的学习笔记

    1 引用 • 1 回帖 • 15 关注
  • 前端

    前端技术一般分为前端设计和前端开发,前端设计可以理解为网站的视觉设计,前端开发则是网站的前台代码实现,包括 HTML、CSS 以及 JavaScript 等。

    247 引用 • 1348 回帖
  • Flume

    Flume 是一套分布式的、可靠的,可用于有效地收集、聚合和搬运大量日志数据的服务架构。

    9 引用 • 6 回帖 • 637 关注
  • Sym

    Sym 是一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)系统平台。

    下一代的社区系统,为未来而构建

    524 引用 • 4601 回帖 • 700 关注
  • CAP

    CAP 指的是在一个分布式系统中, Consistency(一致性)、 Availability(可用性)、Partition tolerance(分区容错性),三者不可兼得。

    11 引用 • 5 回帖 • 613 关注
  • BAE

    百度应用引擎(Baidu App Engine)提供了 PHP、Java、Python 的执行环境,以及云存储、消息服务、云数据库等全面的云服务。它可以让开发者实现自动地部署和管理应用,并且提供动态扩容和负载均衡的运行环境,让开发者不用考虑高成本的运维工作,只需专注于业务逻辑,大大降低了开发者学习和迁移的成本。

    19 引用 • 75 回帖 • 653 关注
  • SVN

    SVN 是 Subversion 的简称,是一个开放源代码的版本控制系统,相较于 RCS、CVS,它采用了分支管理系统,它的设计目标就是取代 CVS。

    29 引用 • 98 回帖 • 694 关注
  • 导航

    各种网址链接、内容导航。

    42 引用 • 175 回帖
  • RIP

    愿逝者安息!

    8 引用 • 92 回帖 • 364 关注
  • 工具

    子曰:“工欲善其事,必先利其器。”

    288 引用 • 734 回帖
  • NetBeans

    NetBeans 是一个始于 1997 年的 Xelfi 计划,本身是捷克布拉格查理大学的数学及物理学院的学生计划。此计划延伸而成立了一家公司进而发展这个商用版本的 NetBeans IDE,直到 1999 年 Sun 买下此公司。Sun 于次年(2000 年)六月将 NetBeans IDE 开源,直到现在 NetBeans 的社群依然持续增长。

    78 引用 • 102 回帖 • 684 关注
  • MyBatis

    MyBatis 本是 Apache 软件基金会 的一个开源项目 iBatis,2010 年这个项目由 Apache 软件基金会迁移到了 google code,并且改名为 MyBatis ,2013 年 11 月再次迁移到了 GitHub。

    170 引用 • 414 回帖 • 388 关注
  • Node.js

    Node.js 是一个基于 Chrome JavaScript 运行时建立的平台, 用于方便地搭建响应速度快、易于扩展的网络应用。Node.js 使用事件驱动, 非阻塞 I/O 模型而得以轻量和高效。

    139 引用 • 269 回帖 • 29 关注
  • Postman

    Postman 是一款简单好用的 HTTP API 调试工具。

    4 引用 • 3 回帖 • 9 关注
  • 旅游

    希望你我能在旅途中找到人生的下一站。

    93 引用 • 899 回帖 • 1 关注
  • 宕机

    宕机,多指一些网站、游戏、网络应用等服务器一种区别于正常运行的状态,也叫“Down 机”、“当机”或“死机”。宕机状态不仅仅是指服务器“挂掉了”、“死机了”状态,也包括服务器假死、停用、关闭等一些原因而导致出现的不能够正常运行的状态。

    13 引用 • 82 回帖 • 61 关注
  • 学习

    “梦想从学习开始,事业从实践起步” —— 习近平

    171 引用 • 512 回帖
  • sts
    2 引用 • 2 回帖 • 198 关注
  • Jenkins

    Jenkins 是一套开源的持续集成工具。它提供了非常丰富的插件,让构建、部署、自动化集成项目变得简单易用。

    53 引用 • 37 回帖 • 2 关注
  • WebSocket

    WebSocket 是 HTML5 中定义的一种新协议,它实现了浏览器与服务器之间的全双工通信(full-duplex)。

    48 引用 • 206 回帖 • 318 关注