当前位置: 代码网 > it编程>数据库>Mysql > MySQL之初始化数据详解

MySQL之初始化数据详解

2025年02月13日 Mysql 我要评论
mysql命令行基本命令列出当前数据库管理系统中有哪些数据库。show databases;创建数据库,起名bjpowernode。create database bjpowernode;使用bjpo

mysql命令行基本命令

列出当前数据库管理系统中有哪些数据库。

show databases;

创建数据库,起名bjpowernode。

create database bjpowernode;

使用bjpowernode数据库。

use bjpowernode;

查看当前用的是哪个数据库。

select database();

查看当前数据库中有哪些表。

show tables;

删除数据库bjpowernode。

drop database bjpowernode;

退出mysqlexitquitctrl + c查看当前mysql版本

select version();

还可以使用mysql.exe命令来查看版本信息(在没有登录mysql之前使用):mysql --version

数据库表的概述

nameagegender
张三20
李四22

以上就是数据库表格的直观展示形式。

表格英文单词table。

表是数据库存储数据的基本单元,数据库存储数据的时候,是将数据存储在表对象当中的。为什么将数据存储在表中呢?因为表存储数据非常直观。

任何一张表都有行和列:

  • 行:记录(一行就是一条数据)
  • 列:字段(name字段、age字段、gender字段)

每个字段包含以下属性:

  • 字段名:name、age、gender都是字段的名字
  • 字段的数据类型:每个字段都有数据类型,比如:字符类型、数字类型、日期类型
  • 字段的数据长度:每个字段有可能会有长度的限制
  • 字段的约束:比如某些字段要求该字段下的数据不能重复、不能为空等,用来保证表格中数据合法有效

初始化测试数据

为了方便后面内容的学习,老师提前准备了表以及表中的测试数据,以下是建表并且初始化数据的sql脚本

drop table if exists emp;
drop table if exists dept;
drop table if exists salgrade;

create table dept(deptno int(2) not null ,
	dname varchar(14) ,
	loc varchar(13),
	primary key (deptno)
);
create table emp(empno int(4)  not null ,
	ename varchar(10),
	job varchar(9),
	mgr int(4),
	hiredate date  default null,
	sal double(7,2),
	comm double(7,2),
	primary key (empno),
	deptno int(2) 
);

create table salgrade( grade int,
	losal int,
	hisal int
);

insert into dept ( deptno, dname, loc ) values ( 10, 'accounting', 'new york'); 
insert into dept ( deptno, dname, loc ) values ( 20, 'research', 'dallas'); 
insert into dept ( deptno, dname, loc ) values ( 30, 'sales', 'chicago'); 
insert into dept ( deptno, dname, loc ) values ( 40, 'operations', 'boston'); 
 
insert into emp ( empno, ename, job, mgr, hiredate, sal, comm,deptno ) values ( 7369, 'smith', 'clerk', 7902,  '1980-12-17', 800, null, 20); 
insert into emp ( empno, ename, job, mgr, hiredate, sal, comm,deptno ) values ( 7499, 'allen', 'salesman', 7698,  '1981-02-20', 1600, 300, 30); 
insert into emp ( empno, ename, job, mgr, hiredate, sal, comm,deptno ) values ( 7521, 'ward', 'salesman', 7698,  '1981-02-22', 1250, 500, 30); 
insert into emp ( empno, ename, job, mgr, hiredate, sal, comm,deptno ) values ( 7566, 'jones', 'manager', 7839,  '1981-04-02', 2975, null, 20); 
insert into emp ( empno, ename, job, mgr, hiredate, sal, comm,deptno ) values ( 7654, 'martin', 'salesman', 7698,  '1981-09-28', 1250, 1400, 30); 
insert into emp ( empno, ename, job, mgr, hiredate, sal, comm,deptno ) values ( 7698, 'blake', 'manager', 7839,  '1981-05-01', 2850, null, 30); 
insert into emp ( empno, ename, job, mgr, hiredate, sal, comm,deptno ) values ( 7782, 'clark', 'manager', 7839,  '1981-06-09', 2450, null, 10); 
insert into emp ( empno, ename, job, mgr, hiredate, sal, comm,deptno ) values ( 7788, 'scott', 'analyst', 7566,  '1987-04-19', 3000, null, 20); 
insert into emp ( empno, ename, job, mgr, hiredate, sal, comm,deptno ) values ( 7839, 'king', 'president', null,  '1981-11-17', 5000, null, 10); 
insert into emp ( empno, ename, job, mgr, hiredate, sal, comm,deptno ) values ( 7844, 'turner', 'salesman', 7698,  '1981-09-08', 1500, 0, 30); 
insert into emp ( empno, ename, job, mgr, hiredate, sal, comm,deptno ) values ( 7876, 'adams', 'clerk', 7788,  '1987-05-23', 1100, null, 20); 
insert into emp ( empno, ename, job, mgr, hiredate, sal, comm,deptno ) values ( 7900, 'james', 'clerk', 7698,  '1981-12-03', 950, null, 30); 
insert into emp ( empno, ename, job, mgr, hiredate, sal, comm,deptno ) values ( 7902, 'ford', 'analyst', 7566,  '1981-12-03', 3000, null, 20); 
insert into emp ( empno, ename, job, mgr, hiredate, sal, comm,deptno ) values ( 7934, 'miller', 'clerk', 7782,  '1982-01-23', 1300, null, 10); 
 
insert into salgrade ( grade, losal, hisal ) values ( 1, 700, 1200); 
insert into salgrade ( grade, losal, hisal ) values ( 2, 1201, 1400); 
insert into salgrade ( grade, losal, hisal ) values ( 3, 1401, 2000); 
insert into salgrade ( grade, losal, hisal ) values ( 4, 2001, 3000); 
insert into salgrade ( grade, losal, hisal ) values ( 5, 3001, 9999); 
commit;

什么是sql脚本:文件名是.sql,并且该文件中编写了大量的sql语句,执行sql脚本程序就相当于批量执行sql语句。

你入职的时候,项目一般都是进展了一部分,多数情况下你进项目组的时候数据库的表以及数据都是有的,项目经理第一天可能会给你一个较大的sql脚本文件,你需要执行这个脚本文件来初始化你的本地数据库。(当然,也有可能数据库是共享的。)

创建文件:bjpowernode.sql,把以上sql语句全部复制到sql脚本文件中。

执行sql脚本文件,初始化数据库

  • 第一步:命令窗口登录mysql
  • 第二步:创建数据库bjpowernode(如果之前已经创建就不需要再创建了):create database bjpowernode;
  • 第三步:使用数据库bjpowernode:use bjpowernode;
  • 第四步:source命令执行sql脚本,注意:source命令后面是sql脚本文件的绝对路径。

  • 第五步:查看是否初始化成功,执行:show tables;

使用其他的mysql客户端工具也可以执行sql脚本,比如navicat。使用source命令执行sql脚本的优点:可支持大文件

熟悉测试数据

emp dept salgrade三张表分别存储什么信息

查看表结构:desc或describe,语法格式:desc或describe +表名

以上的结果展示的不是表中的数据,而是表的结构。

对以上表结构进行解释说明:

  • emp
  • dept
  • salgrade

对于以上表结构要提前了解,后面学习的内容需要你马上反应出:哪个字段是什么意思。

查看一下表中的数据,来加深一下印象(以下sql语句会在后面课程中学习):

  • emp:员工信息
  • dept:部门信息
  • salgrade:工资等级信息
  • field是字段名
  • type是这个字段的数据类型
  • null是这个字段是否允许为空
  • key是这个字段是否为主键或外键
  • default是这个字段的默认值
  • empno:员工编号,int类型(整数),不能为空,主键(主键后期学习约束时会进行说明)
  • ename:员工姓名,varchar类型(字符串)
  • job:工作岗位,varchar类型
  • mgr:上级领导编号,int类型
  • hiredate:雇佣日期,date类型(日期类型)
  • sal:月薪,double类型(带有浮点的数字)
  • comm:补助津贴,double类型
  • deptno:部门编号,int类型
  • deptno:部门编号,int类型,主键
  • dname:部门名称,varchar类型
  • loc:位置,varchar类型
  • grade:等级,int类型
  • losal:最低工资,int类型
  • hisal:最高工资,int类型

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com