MySQL史上最全命令语法

一、数据库概述
数据库(DataBase,DB):指长期保存在计算机的存储设备上,按照一定规则组织起来,可以被各种用户或应用共享的数据集合。

数据库管理系统(DataBase Management System,DBMS):指一种操作和管理数据库的大型软件,用于建立、使用和维护数据库,对数据库进行统一管理和控制,以保证数据库的安全性和完整性。用户通过数据库管理系统访问数据库中的数据。

数据库软件应该为数据库管理系统,数据库是通过数据库管理系统创建和操作的。

数据库:存储、维护和管理数据的集合。
二、数据库的安装与配置
* 安装
* 参照图解
* 一路下一步
* 卸载
1.停止mysql服务 net stop mysql 启动mysql服务 net start mysql
2.卸载mysql
3.找到mysql 安装目录下的 my.ini datadir=“C:/ProgramData/MySQL/MySQL Server 5.5/Data/”
* 运行
* 安装成功了打开cmd --> mysql -uroot -p你的密码
* 修改mysql root用户密码
1) 停止mysql服务 运行输入services.msc 停止mysql服务
或者 cmd --> net stop mysql
2) 在cmd下 输入 mysqld --skip-grant-tables 启动服务器 光标不动 (不要关闭该窗口)
3) 新打开cmd 输入mysql -u root -p 不需要密码
use mysql;
update user set password=password(‘abc’) WHERE User=‘root’;
4) 关闭两个cmd窗口 在任务管理器结束mysqld 进程
5) 在服务管理页面 重启mysql 服务
密码修改完成

* 配置
	* 参照图解
	* 到选择字符集时停

三、sql概述
SQL:Structure Query Language。(结构化查询语言)
SQL被美国国家标准局(ANSI)确定为关系型数据库语言的美国标准,后来被国际化标准组织(ISO)采纳为关系数据库语言的国际标准。

各数据库厂商都支持ISO的SQL标准。普通话
各数据库厂商在标准的基础上做了自己的扩展。方言
四、Sql的分类
DDL(*)(Data Definition Language):数据定义语言,用来定义数据库对象:库、表、列等;
DML()(Data Manipulation Language):数据操作语言,用来定义数据库记录(数据);
DCL(Data Control Language):数据控制语言,用来定义访问权限和安全级别;
DQL(
***)(Data Query Language):数据查询语言,用来查询记录(数据)。

  • 注意:sql语句以;结尾

4.1 DDL:操作数据库、表、列等
使用的关键字:CREATE、 ALTER、 DROP

  • 4.1.1操作数据库
    创建
    Create database mydb1;
    Create database mydb2 character set gbk;
    Create database mydb3 character set gbk COLLATE gbk_chinese_ci;

      查询
    

查看当前数据库服务器中的所有数据库
Show databases;
查看前面创建的mydb2数据库的定义信息
Show create database mydb2;
删除前面创建的mydb3数据库
Drop database mydb3;

	修改
			 查看服务器中的数据库,并把mydb2的字符集修改为utf8;

alter database mydb2 character set utf8;
删除
Drop database mydb3;

	* 其他:

查看当前使用的数据库
Select database();
切换数据库
Use mydb2;

  • 4.1.2操作数据表
    • 语法:
      create table 表名(
      字段1 字段类型,
      字段2 字段类型,

      字段n 字段类型
      );

    • 常用数据类型:
      int:整型
      double:浮点型,例如double(5,2)表示最多5位,其中必须有2位小数,即最大值为999.99;
      char:固定长度字符串类型; char(10) 'aaa ’ 占10位
      varchar:可变长度字符串类型; varchar(10) ‘aaa’ 占3为
      text:字符串类型;
      blob:字节类型;
      date:日期类型,格式为:yyyy-MM-dd;
      time:时间类型,格式为:hh:mm:ss
      timestamp:时间戳类型 yyyy-MM-dd hh:mm:ss 会自动赋值
      datetime:日期时间类型 yyyy-MM-dd hh:mm:ss
      字段 属性
      Id 整型
      name 字符型
      gender 字符型
      birthday 日期型
      Entry_date 日期型
      job 字符型
      Salary 小数型
      resume 大文本型

当前数据库中的所有表
SHOW TABLES;
查看表的字段信息
DESC employee;
在上面员工表的基本上增加一个image列。
ALTER TABLE employee ADD image blob;
修改job列,使其长度为60。
ALTER TABLE employee MODIFY job varchar(60);
删除image列,一次只能删一列。
ALTER TABLE employee DROP image;
表名改为user。
RENAME TABLE employee TO user;
查看表格的创建细节
SHOW CREATE TABLE user;
修改表的字符集为gbk
ALTER TABLE user CHARACTER SET gbk;
列名name修改为username
ALTER TABLE user CHANGE name username varchar(100);

删除表
DROP TABLE user ;

4.2 DML操作(重要)
查询表中的所有数据
SELECT * FROM 表名;

DML是对表中的数据进行增、删、改的操作。不要与DDL混淆了。
INSERT 、UPDATE、 DELETE

小知识:
在mysql中,字符串类型和日期类型都要用单引号括起来。
空值:null
4.2.1插入操作:INSERT:
语法: INSERT INTO 表名(列名1,列名2 …)VALUES(列值1,列值2…);
注意:列名与列值的类型、个数、顺序要一一对应。
可以把列名当做java中的形参,把列值当做实参。
参不要超出列定义的长度。
如果插入空值,请使用null
插入的日期和字符一样,都使用引号括起来。
练习 :
create table emp(
id int,
name varchar(100),
gender varchar(10),
birthday date,
salary float(10,2),
entry_date date,
resume text
);

INSERT INTO emp(id,name,gender,birthday,salary,entry_date,resume)
VALUES(1,‘zhangsan’,‘female’,‘1990-5-10’,10000,‘2015-5-5-’,‘good girl’);

INSERT INTO emp(id,name,gender,birthday,salary,entry_date,resume)
VALUES(2,‘lisi’,‘male’,‘1995-5-10’,10000,‘2015-5-5’,‘good boy’);

INSERT INTO emp(id,name,gender,birthday,salary,entry_date,resume)
VALUES(3,‘你好’,‘male’,‘1995-5-10’,10000,‘2015-5-5’,‘good boy’);

在这里插入图片描述

小知识:
查看数据库编码的具体信息
Show variables like ‘character%’;

在这里插入图片描述

临时更改客户端和服务器结果集的编码
Set character_set_client=gbk;
Set character_set_results=gbk;

4.2.2 修改操作 UPDATE:
语法:UPDATE 表名 SET 列名1=列值1,列名2=列值2 。。。 WHERE 列名=值

练习:
将所有员工薪水修改为5000元。
UPDATE emp SET salary=5000
将姓名为’zs’的员工薪水修改为3000元。
UPDATE emp SET salary=3000 WHERE name=’ zhangsan’;
将姓名为’aaa’的员工薪水修改为4000元,job改为ccc。
UPDATE emp SET salary=4000,gender=‘female’ WHERE name=‘lisi’;
将wu的薪水在原有基础上增加1000元。
UPDATE emp SET salary=salary+1000 WHERE gender=‘male’;

4.2

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_ks℘ℳJJ、意中人๓

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值