- Java锁的逻辑(结合对象头和ObjectMonitor)
- 还在用饼状图?来瞧瞧这些炫酷的百分比可视化新图形(附代码实现)⛵
- 自动注册实体类到EntityFrameworkCore上下文,并适配ABP及ABPVNext
- 基于Sklearn机器学习代码实战
根据上一篇文章 【必知必会的MySQL知识】①初探MySQL 的内容,想必您对MySQL数据库有了一个整体的了解了,并且应该在自己电脑上已经安装上了MySQL。 这一篇呢我们来说一说这么连接上数据库并且使用它.
前面MySQL安装的文章 手把手教你安装MySQL 中我们已经说过怎么启动服务了。这里呢再简单说一下。 启动MySQL服务有以下两种方式 。
1、 使用命令启动 。
进入到MySQL安装目录的bin目录下,并输入命令启动、停止服务 。
# 启动MySQL服务
net start mysql
# 停止MySQL服务
net stop mysql
2、进入服务页面进行启动 。
右键选中此电脑-->管理-->服务与应用程序-->服务-->找到MySQL服务-->右键服务即可启动、关闭、重启MySQL服务 。
当然了,我们还可以设置 MySQL服务 开机自启动,这样每次电脑开机MySQL服务就会自动启动了 。
MySQL服务启动后,我们就可以通过各种工具来连接我们的MySQL数据库了。下面我们将通过最原始的命令行及各种第三方工具演示连接MySQL数据库 。
1、通过命令行连接 。
# 命令格式
mysql [-h 127.0.0.1] [-P 3306] -u root -p
-h : MySQL服务所在的主机IP,本地数据库IP为127.0.0.1
-P : MySQL服务端口号,默认为3306
-u : MySQL数据库用户名
-p : MySQL数据库用户名对应的密码
[]内为可选参数,如果需要连接远程的MySQL,需要加上这两个参数来指定远程主机IP、端口,如果
连接本地的MySQL,则无需指定这两个参数
注: 有时候我们会遇到如下错误 遇到这样的错误呢,我们也不要慌。上面报错是因为找不到 mysql命令 报的,所以呢解决办法就是将路径切换到MySQL的安装路径的bin目录下再执行如下命令即可 。
myslq -u root -p
2、通过各种第三方工具连接 。
当然了,日常开发中,我们一般不会使用命令行的方式连接数据库的。而是通过第三方工具去连。 这里呢推荐几个小编认为不错的工具供大家参考。① sqlyog ② Navicat ③ DataGrip ① sqlyog 和② Navicat两个工具体积不大,占用内存也比较小,个人使用起来,各种常用功能都有了。 如果你的电脑配置比较好也可以使用③ DataGrip 不管使用哪个工具都是可以的 。
下载地址: ① sqlyog 链接: https://pan.baidu.com/s/1yDooGbVxqAfwrrsEJ2_Tug 提取码:mbd0 ② Navicat 链接: https://pan.baidu.com/s/1yDooGbVxqAfwrrsEJ2_Tug 提取码:9yoe ③ DataGrip 链接: https://pan.baidu.com/s/11PyoGQKAyX-pX2NroapqpQ 提取码:1ei2 各个第三方工具连接MySQL配置 ①sqlyog ② Navicat ③ DataGrip 不管使用哪种工具,连接配置都还是比较简单的.
1、基本命令 。
# 基本命令
SHOW DATABASES; --查看当前用户下所有数据库
CREATE DATABASE [IF NOT EXISTS] 数据库名; --创建一个数据库
SHOW CREATE DATABASE 数据库名;-- 查看创建数据库的语句
DROP DATABASE [if EXISTS] 数据库名; --删除数据库
show databases; --查看当前所有的数据库
use 数据库名; --打开指定的数据库
SHOW CREATE TABLE 表名;-- 查看表的定义语句
DROP TABLE 表名; --删除表
show tables; --查看所有的表
desc 表名; --显示表的信息
exit --退出连接
2、注释 。
-- --单行注释
# --单行注释
/*...*/ --多行注释
3、 关键字 。
上面基本命令中,我们使用的show、databases、create、use、desc 等词都是MySQL关键字。顾名思义, 关键字 就是一些用于执行MySQL操作的特殊词汇,时MySQL自带的。所以, 在命名数据库、表、列和其他对象时,一定不要使用这些关键字 。
具体关键字可以参考 【必知必会的MySQL知识】附录Ⅰ 5.7版本 。
4、实践操作 注: 虽然上面我们介绍了三种图形化连接MySQL工具,这一节我们还是使用命令行进行演示.
① 查看root用户下可用数据库 。
# 我们可以看到,root 用户下一共有5个可用数据库,前四个时MySQL自带的数据库,
#最后一个test数据库时我们后来创建的,我们这里暂时还不用知道这些数据库具体时干嘛的
# 只需要知道有这么个东西就可以了,后面会具体说
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| sys |
| test |
+--------------------+
5 rows in set (0.00 sec)
② 创建一个自己的数据库 。
# 创建了一个名叫db_xiezhr的数据库
mysql> create database if not exists db_xiezhr;
Query OK, 1 row affected (0.02 sec)
# 通过命令show databases; 我们可以看到,上面的创建脚本生效了,可用数据库多了db_xiezhr
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| db_xiezhr |
| mysql |
| performance_schema |
| sys |
| test |
+--------------------+
6 rows in set (0.00 sec)
③ 查看创建数据库脚本 。
# 根据如下脚本,我们可以看到上面创建db_xiezhr数据库时的脚本
mysql> show create database db_xiezhr;
+-----------+----------------------------------------------------------------------+
| Database | Create Database |
+-----------+----------------------------------------------------------------------+
| db_xiezhr | CREATE DATABASE `db_xiezhr` /*!40100 DEFAULT CHARACTER SET latin1 */ |
+-----------+----------------------------------------------------------------------+
1 row in set (0.02 sec)
④ 选择数据库 。
上面根据show dabatases命令已经列出了root用户下的所有数据库,我们要选择其中的一个,才能操作它 。
# 选择我们创建的数据库db_xiezhr
mysql> use db_xiezhr
Database changed
⑤在db_xiezhr 数据库下创建一张表 格式 。
CREATE TABLE IF NOT EXISTS `student`(
'字段名' 列类型 [属性] [索引] [注释],
'字段名' 列类型 [属性] [索引] [注释],
......
'字段名' 列类型 [属性] [索引] [注释]
)[表的类型][字符集设置][注释]
# 在数据库db_xiezhr 中创建一张用户表
--表名和字段尽量使用``括起来
--AUTO_INCREMENT 代表自增
--所有的语句后面加逗号,最后一个不加
--字符串使用单引号括起来
--主键的声明一般放在最后,便于查看
--不设置字符集编码的话,会使用MySQL默认的字符集编码Latin1,不支持中文,可以在my.ini里修改
mysql> CREATE TABLE IF NOT EXISTS `t_account`(
-> `id` INT(4)NOT NULL AUTO_INCREMENT COMMENT '学号',
-> `username` VARCHAR(30) NOT NULL DEFAULT '匿名' COMMENT '姓名',
-> `psw` VARCHAR(20) NOT NULL DEFAULT '123456' COMMENT '密码',
-> `sexcode` VARCHAR(1) NOT NULL DEFAULT '1' COMMENT '性别 1男 2女',
-> `birthday` DATETIME DEFAULT NULL COMMENT '出生日期',
-> `address` VARCHAR(100) DEFAULT NULL COMMENT '家庭住址',
-> `email` VARCHAR(50) DEFAULT NULL COMMENT '邮箱',
-> PRIMARY KEY (`id`)
-> )ENGINE=INNODB DEFAULT CHARSET=utf8
-> ;
Query OK, 0 rows affected (0.03 sec)
⑥ 查看建表语句 。
# 查看上面建t_account表的语句
mysql> show create table t_account;
+-----------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table |
+-----------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| t_account | CREATE TABLE `t_account` (
`id` int(4) NOT NULL AUTO_INCREMENT COMMENT '学号',
`username` varchar(30) NOT NULL DEFAULT '匿名' COMMENT '姓名',
`psw` varchar(20) NOT NULL DEFAULT '123456' COMMENT '密码',
`sexcode` varchar(1) NOT NULL DEFAULT '1' COMMENT '性别 1男 2女',
`birthday` datetime DEFAULT NULL COMMENT '出生日期',
`address` varchar(100) DEFAULT NULL COMMENT '家庭住址',
`email` varchar(50) DEFAULT NULL COMMENT '邮箱',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |
+-----------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.02 sec)
⑦ 查看表“t_account” 的结构 。
# 查看我们上面所建的表t_account
mysql> desc t_account;
+----------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+----------+--------------+------+-----+---------+----------------+
| id | int(4) | NO | PRI | NULL | auto_increment |
| username | varchar(30) | NO | | 匿名 | |
| psw | varchar(20) | NO | | 123456 | |
| sexcode | varchar(1) | NO | | 1 | |
| birthday | datetime | YES | | NULL | |
| address | varchar(100) | YES | | NULL | |
| email | varchar(50) | YES | | NULL | |
+----------+--------------+------+-----+---------+----------------+
7 rows in set (0.01 sec)
⑧ 查看数据库中所有表 。
# 查看db_xiezhr 数据库中所有表(数据库中只有我们刚刚建的t_account表)
mysql> show tables;
+---------------------+
| Tables_in_db_xiezhr |
+---------------------+
| t_account |
+---------------------+
1 row in set (0.00 sec)
⑨ 删除表 。
# 删除我们创建的t_account表,如果是在生产环境,删除数据库一定一定一定要慎重。要不然就只能跑路了
#删除表t_account
mysql> drop table t_account;
Query OK, 0 rows affected (0.01 sec)
# 执行上面语句后,再查看数据库表,发现t_account 表已经不在了
mysql> show tables;
Empty set (0.00 sec)
⑩ 删除数据库 。
# 删除我们创建的db_xiezhr数据库,如果是在生产环境,删除数据库一定一定一定要慎重。要不然就只能跑路了
# 删除db_xiezhr数据库
mysql> drop database db_xiezhr;
Query OK, 0 rows affected (0.01 sec)
# 再用show databases;查所有数据库时,我们发现db_xiezhr数据库已经不在了
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| sys |
| test |
+--------------------+
5 rows in set (0.00 sec)
⑪ 退出MySQL 。
# 这期文章我们就说到这里了,该休息了。我们将连接的MySQL退出
# 退出MySQL连接,MySQL还跟我们说了一声Bye (●'◡'●)
mysql> exit;
Bye
D:\DeveSoftware\mysql-5.7.37-winx64\bin>
这一篇文章主要是说了怎么连接MySQL数据库、推荐了三款比较好用图形化工具Sqlyog、Navicat、Datagrip。 参照上面文章,相信你可以成功连接自己本地数据库或者远程服务器上的MySQL了 以及对MySQL数据库进行一些基本操作了。 其实,我们本文章用到的基本操作都属于 数据库定义语言(DDL) .
SQL语句 根据其功能可以分为: DDL、DML、DQL、DCL 四类 。
后续文章中,我们会依次对剩下的SQL进行讲解,并且会通过刷题网站进行实战操作。敬请期待哦 (●'◡'●) 。
如果觉得内容不错,防止以后找不到,可以点赞、收藏、关注哦。 (●'◡'●) 。
最后此篇关于【必知必会的MySQL知识】②使用MySQL的文章就讲到这里了,如果你想了解更多关于【必知必会的MySQL知识】②使用MySQL的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
积累和总结,是长期持续的过程 01 最近,很多朋友微信私聊关于「 butte-java-note 」仓库的话题; 这个「 Git仓库 」每年都会
我即将参加挑战测试,所以我不必参加数据库处理类(class)。尽管在过去的 5 年里我一直在使用数据库,但我还是忍不住对测试感到紧张。这是 50 个问题,有 2 部分:真/假部分和我实际编写 SQL
我的 groovy 代码将 Rabbit Native Plugin 用于 grails: def handleMessage(def body, MessageContext context) {
我想看看是否有人可以就我在 .NET 环境中的进一步知识提供任何建议... 这里有一点背景。我上了一所大学并获得了计算机科学学士学位(主要从事 C、Java 和 C++ 方面的工作)。大学毕业后在一家
我在 postgres 数据库中有一个表,该表用于测试环境,我们需要一次添加和删除多个列。问题是 postgres 最多有 1600 列,并且这个计数包括丢弃的列。我的表永远不会有 1600 个“未丢
作为业余程序员 3 年(主要是 Python 和 C)并且从未编写过超过 500 行代码的应用程序,我发现自己面临两个选择: (1) 学习数据结构和算法设计的基本知识,使我成为一名 l33t 计算机科
有人能告诉我为什么 Android 工作需要 Linux 知识吗?许多 Android 工作都以 Linux 作为先决条件。我可以很好地从 Windows 机器开发 Android 应用程序吗? 最佳
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 10 年前。 Improve thi
是否可以在 Drools 中保持知识 session ?如果是这样,如何? 我将事实存储在数据库中,并且每次添加新事实时,我都希望避免在新 session 中重新加载所有事实。 目前,当有新事实时,该
我对 C++ 有很好的了解,但从未深入研究 STL。我必须学习 STL 的哪一部分才能提高工作效率并减少工作中的缺陷? 谢谢。 最佳答案 I have good knowledge of C++ 恕我
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 9 年前。 Improve
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 7 年前。 Improve
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
在我从 SO answers here 和许多 BackBoneJs 示例中选择的示例之一中,我看到初始化函数知道模型将使用哪个 View 进行渲染。我不知道我现在有点偏见,这是一个好的做法还是取决于
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 12 年前。 Improve thi
我在我的网站上使用 C# 和 ASP.NET MVC 3 实现 OpenID 和 OAuth。我基于 DotNetOpenAuth用于后端和openid-selector对于前端。 我喜欢 openi
很长一段时间以来,我都在思考和研究C语言编译器以汇编形式的输出,以及CPU架构。我知道这对你来说可能很愚蠢,但在我看来有些东西是非常无效的。如果我错了,请不要生气,我不明白所有这些原则是有原因的。如果
我有一些 Python 知识,但我从来不认为自己对这门语言特别流利。我正在开发一个潜在的机器视觉项目,该项目将从 SimpleCV 中受益匪浅,但从时间的角度来看,我宁愿不必非常流利地使用 pytho
我是一名优秀的程序员,十分优秀!