修改密码


这是常见的大家一般都要用的

  首先安装成功了打开cmd --> mysql -u root -p -->输入你的密码

-->修改mysql root用户密码

   格式:mysql> set password for 用户名@localhost = password(‘新密码’);

   举例:mysql> set password for root@localhost = password(‘root’);

上面例子将用户root的密码更改为root;

如果是学习使用一般密码该简单些,如root,123等,这样便于记忆。

接下来就是SQL语句了,进入今天的主题了:

SQL:Structure Query Language。(结构化查询语言)

Sql的分类


DDL (Data Definition Language):数据定义语言,用来定义数据库对象:库、表、列等; CREATE、 ALTER、DROP

DML(Data Manipulation Language):数据操作语言,用来定义数据库记录(数据); INSERT、 UPDATE、 DELETE

DCL(Data Control Language):数据控制语言,用来定义访问权限和安全级别;

DQL(Data Query Language):数据查询语言,用来查询记录(数据)。

SELECT

*注意:sql语句以 ; 结尾

这些都是数据库的SQL的基础知识(也是常识),一定要记住。

DDL:操作数据库、表、列等


使用的关键字:CREATEALTERDROP

创建

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;

操作数据表

语法:创建数据库

create table 表名(
字段1 字段类型,
字段2 字段类型,
...
字段n 字段类型
);

常用数据类型


int:整型

double:浮点型,例如double(5,2)表示最多5位,其中必须有2位小数,即最大值为999.99;

char:固定长度字符串类型; char(10) 'abc '

varchar:可变长度字符串类型;varchar(10) 'abc'

text:字符串类型;

blob:字节类型;

date:日期类型,格式为:yyyy-MM-dd;

time:时间类型,格式为:hh:mm:ss

timestamp:时间戳类型 yyyy-MM-dd hh:mm:ss 会自动赋值

datetime:日期时间类型 yyyy-MM-dd hh:mm:ss

重点:

当前数据库中的所有表

SHOW TABLES;

查看表的字段信息

DESC emp;

在上面员工表的基本上增加一个image列。

ALTER TABLE emp ADD image blob;

修改job列,使其长度为60。

ALTER TABLE emp MODIFY job varchar(60);

删除image列,一次只能删一列。

ALTER TABLE em DROP image;

表名改为user。

RENAME TABLE emp TO user;

查看表格的创建细节

SHOW CREATE TABLE user;

修改表的字符集为utd-8

ALTER TABLE user CHARACTER SET utf-8;

列名name修改为username

ALTER TABLE user CHANGE name username varchar(100);

删除表

DROP TABLE user ;

DML操作(重要)


查询表中的所有数据

SELECT * FROM 表名;

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

INSERT 、UPDATE、 DELETE

注意事项:

  在mysql中,字符串类型和日期类型都要用单引号括起来。'tom' '2017-07-10'

  空值:null

插入操作:INSERT:

语法: INSERT INTO 表名(列名1,列名2 ...)VALUES(列值1,列值2...);

注意:列名与列值的类型、个数、顺序要一一对应。

   可以把列名当做java中的形参,把列值当做实参。

   值不要超出列定义的长度。

   如果插入空值,请使用null

   插入的日期和字符一样,都使用引号括起来。

修改操作 UPDATE:

  语法:UPDATE 表名 SET 列名1=列值1,列名2=列值2 ........ WHERE 列名=值

删除操作 DELETE:

语法 : DELETE FROM 表名 【WHERE 列名=值】

注意:where语句可以不写

   DELETE :删除表中的数据,表结构还在;删除后的数据可以找回。

   TRUNCATE :删除是把表直接DROP掉,然后再创建一个同样的新表。

   删除的数据不能找回。执行速度比DELETE快。

DQL操作


  DQL数据查询语言 (重要):这个我们经常用因为数据库建好了之后我们主要用的就是去查询我们想要的数据,然后把它显示在页面上。

  数据库执行DQL语句不会对数据进行改变,而是让数据库发送结果集给客户端。

  查询返回的结果集是一张虚拟表。

查询关键字:SELECT

语法: SELECT 列名 FROM表名

【WHERE --> GROUP BY -->HAVING--> ORDER BY】

语法:

  SELECT selection_list /*要查询的列名称*/
FROM table_list /*要查询的表名称*/
WHERE condition /*行条件*/
GROUP BY grouping_columns /*对结果分组*/
HAVING condition /*分组后的行条件*/
ORDER BY sorting_columns /*对结果分组*/
LIMIT offset_start, row_count /*结果限定*/

查询代码的书写顺序和执行顺序

 查询语句书写顺序:select – from- where- group by- having- order by-limit

 查询语句执行顺序:from - where -group by - having - select - order by-limit

查询所有列

SELECT * FROM 表名;

查询指定列

SELECT 列名 FROM 表名;

条件查询

条件查询就是在查询时给出WHERE子句,在WHERE子句中可以使用如下运算符及关键字:

  =、!=、<>、<、<=、>、>=;

  BETWEEN…AND;

  IN(set);

  IS NULL; IS NOT NULL

  AND;

  OR;

  NOT;

模糊查询

  当想查询姓名中包含a字母的学生时就需要使用模糊查询了。模糊查询需要使用关键字LIKE。

 通配符:

  "_"     :任意一个字符

  "% "     :任意0~n个字符

字段控制查询


  • 去除重复记录:

   去除重复记录(两行或两行以上记录中系列的上的数据都相同)。

 语法:

    SELECT DISTINCT 列名 FROM 表名;


  • 给列名添加别名

  *SELECT ,列名 AS 别名 FROM 表名;

  给列起别名时,是可以省略AS关键字的:

  *SELECT ,列名 别名 FROM 表名;


排序 order by 列名 asc(默认) desc

语法:

  • ORDER BY 列名 ASC;

  • ORDER BY 列名 DESC;

#### **聚合函数 sum avg max min count**


聚合函数是用来做纵向运算的函数:

  • COUNT():统计指定列不为NULL的记录行数;

  • MAX():计算指定列的最大值,如果指定列是字符串类型,那么使用字符串排序运算;

  • MIN():计算指定列的最小值,如果指定列是字符串类型,那么使用字符串排序运算;

  • SUM():计算指定列的数值和,如果指定列类型不是数值类型,那么计算结果为0;

  • AVG():计算指定列的平均值,如果指定列类型不是数值类型,那么计算结果为0;

举例:

COUNT


当需要纵向统计时可以使用COUNT()。

  • 查询emp表中记录数:
	SELECT COUNT(*) AS cnt FROM emp;
  • 查询emp表中有佣金的人数:
	SELECT COUNT(comm) cnt FROM emp;

注意,因为count()函数中给出的是comm列,那么只统计comm列非NULL的行数。

  • 查询emp表中月薪大于2500的人数:
SELECT COUNT(*) FROM emp
WHERE sal > 2500;
  • 统计月薪与佣金之和大于2500元的人数:
SELECT COUNT(*) AS cnt FROM emp WHERE sal+IFNULL(comm,0) > 2500;
  • 查询有佣金的人数,有领导的人数:

    SELECT COUNT(comm), COUNT(mgr) FROM emp;

SUM和AVG


当需要纵向求和时使用sum()函数。

  • 查询所有雇员月薪和:
SELECT SUM(sal) FROM emp;
  • 查询所有雇员月薪和,以及所有雇员佣金和:
SELECT SUM(sal), SUM(comm) FROM emp;
  • 查询所有雇员月薪+佣金和:
SELECT SUM(sal+IFNULL(comm,0)) FROM emp;
  • 统计所有员工平均工资:
SELECT AVG(sal) FROM emp;

MAX和MIN


  • 查询最高工资和最低工资:
SELECT MAX(sal), MIN(sal) FROM emp;

分组查询


  当需要分组查询时需要使用GROUP BY子句,例如查询每个部门的工资和,这说明要使用部门来分组。

  注:凡和聚合函数同时出现的列名,一定要写在group by 之后

HAVING子句


  • 查询工资总和大于9000的部门编号以及工资和:
	SELECT deptno, SUM(sal)
FROM emp
GROUP BY deptno
HAVING SUM(sal) > 9000;

  注:having与where的区别:

   1.having是在分组后对数据进行过滤.

    where是在分组前对数据进行过滤

   2.having后面可以使用聚合函数(统计函数)

     where后面不可以使用聚合函数。

    WHERE是对分组前记录的条件,如果某行记录没有满足WHERE子句的条件,那么这行记录不会参加分组;而HAVING是对分组后数据的约束。

LIMIT(分页查询) MySQL自己的sql语句


LIMIT用来限定查询结果的起始行,以及总行数。

  • 查询5行记录,起始行从0开始
SELECT * FROM 表名 LIMIT 0, 5;

  注意,起始行从0开始,即第一行开始!

  • 查询10行记录,起始行从3开始
SELECT * FROM emp LIMIT 3, 10;

分页查询

  如果一页记录为10条,希望查看第3页记录应该怎么查呢?

  第一页记录起始行为0,一共查询10行;

  第二页记录起始行为10,一共查询10行;

  第三页记录起始行为20,一共查询10行;

最后一部分

主键、唯一性约束、自动增长、默认值、非空约束


  这里我就大概写几个代码你们看下,因为这里都比较简单。至于触发器这个一般都不在数据库写了一般直接在java代码中操作了,约束也可以直接用js等语言去约束。

		-- 第一种
CREATE TABLE student(
Id int primary key,
Name varchar(50)
);
-- 第二种
CREATE TABLE student(
id int,
Name varchar(50),
Primary key(id)
); -- 也属于第二种吧(多个主键)
CREATE TABLE student(
id int,
Name varchar(50),
Primary key(id,name)
); -- 第三种
CREATE TABLE student(
Id int,
Name varchar(50)
);
ALTER TABLE student
ADD PRIMARY KEY (id);

唯一性约束

CREATE TABLE student(
Id int primary key,
Name varchar(50) unique
);

自动增长列(auto_increment)

给主键添加自动增长的数值,列只能是整数类型,但是如果删除之前增长的序号,后面再添加的时候序号不会重新开始,而是会接着被删除的那一列的序号

CREATE TABLE student(
Id int primary key auto_increment,
Name varchar(50)
);

默认值default

CREATE TABLE student(
Id int pirmary key,
Name varchar(50) not null,
Sex varchar(10) default ‘男’
);

非空约束:** **null(默认),not null;

CREATE TABLE student(
Id int pirmary key,
Name varchar(50) not null,
Sex varchar(10)
);

  到这里就把常用的MySQL语句写完了,其他的语句都不太常用就没再这里写,如果感觉我写的不错就赞一下。

MySQL的常用SQL语句.md的更多相关文章

  1. mysql整理-常用sql语句

    一.常用sql show variables like 'character_set_client';#查询字符集 show databases;#列出所有的服务器上的数据库alter create ...

  2. MySQL 存储过程常用SQL语句收集

    1,select curdate() /*2016-10-08*/ 2,select date_sub(curdate(), INTERVAL 6 DAY) /*2016-10-02*/ 3,case ...

  3. MySQL之常用SQL语句

    1) 分表之后统计数据的总量 SELECT (a0.total + a1.total + a2.total + a3.total + a4.total + a5.total + a6.total + ...

  4. Mysql 常用 SQL 语句集锦

    Mysql 常用 SQL 语句集锦 基础篇 //查询时间,友好提示 $sql = "select date_format(create_time, '%Y-%m-%d') as day fr ...

  5. Mysql 常用 SQL 语句集锦 转载(https://gold.xitu.io/post/584e7b298d6d81005456eb53)

    Mysql 常用 SQL 语句集锦 基础篇 //查询时间,友好提示 $sql = "select date_format(create_time, '%Y-%m-%d') as day fr ...

  6. 常用sql语句整理:mysql

    ## 常用sql语句整理:mysql1. 增- 增加一张表```CREATE TABLE `table_name`(  ...  )ENGINE=InnoDB DEFAULT CHARSET=utf8 ...

  7. MySQL用户管理、常用sql语句、MySQL数据库备份恢复

    1.MySQL用户管理 给远程登陆用户授权:grant all on *.* to 'user1'@'127.0.0.1' identified by '123456' (这里的127.0.0.1是指 ...

  8. 浅谈MySQL中优化sql语句查询常用的30种方法 - 转载

    浅谈MySQL中优化sql语句查询常用的30种方法 1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中使 ...

  9. mysql 常用 sql 语句 - 快速查询

    Mysql 常用 sql 语句 - 快速查询 1.mysql 基础 1.1 mysql 交互         1.1.1 mysql 连接             mysql.exe -hPup    ...

随机推荐

  1. 阿里云服务器 通过JavaMail发送邮箱STMP问题( 25端口被禁用 使用SSL协议465端口 )

    我们传统使用的比较简单的是 STMP 25端口收发邮件 今天发现刚购买的阿里云服务器不能作为客户端通过STMP 25端口发送邮件 开始在网上有说发现是JDK1.8的原因,然后自己也把JDK1.8换到了 ...

  2. Broker模块划分

    本篇在上一篇<消息中间件架构讨论>的基础上分析Broker的模块划分. 上图是之前讨论确定的系统架构(后续内容会按照这个架构来叙述),几点基础: Broker采用主从结构 Broker负责 ...

  3. 【Vue】详解Vue组件系统

    Vue渲染的两大基础方式 new 一个Vue的实例 这个我们一般会使用在挂载根节点这一初始化操作上: new Vue({ el: '#app' }) 注册组件并使用—— 全局注册 通过Vue.comp ...

  4. hdu_2222: Keywords Search(AC自动机模板题)

    题目链接 统计一段字符串中有多少个模板串在里面出现过 #include<bits/stdc++.h> using namespace std; ; struct Trie { ]; int ...

  5. 【微信小程序开发教程】如何显示群名称?

    今年 5 月份的时候,微信宣布:「为了更好的针对群场景提供个性化服务,当用户在群聊中点击小程序分享卡片时,小程序支持开发者获取群 ID 和群名称」.但随后没多久,发现小程序只返回了群 ID,并没有给我 ...

  6. Java项目 打war包方法

    我们可以运用DOS命令来手工打war包: 首先,打开DOS命令行,敲入"jar",我们发现它提示不是内部或外部的命令这样的错误,这时八成是你的JAVA环境没有配置好,我们可以用JA ...

  7. ps-ef|grep-vgrep|grepsep|awk'{print"kill-9"$2}'|sh 这个表达式到底是什么意思啊?

    最佳答案   kill 掉sep这个程序ps -ef | 获取当前服务器所有进程grep -v grep 相当于grep自己吧自己过滤掉,就是不显示grepgrep seq 过滤出seqawk 截取 ...

  8. 快速排序算法的C语言实现

    #include<stdio.h> int partition(int a[],int low,int high) { int key=a[low]; while(low<high) ...

  9. C# 将数据表导出到Excel通用方法

    DataGrid dg = new DataGrid(); dg.DataSource = dt; dg.DataBind(); Response.Clear(); Response.Buffer = ...

  10. 剑指offer--二叉树的后序遍历

    思路:对于一个二叉树的后序遍历序列来说,最后一个数一定是根节点,然后前面的数中,从最开始到第一个大于根节点的数都是左子树中的数,而后面到倒数第二个数应该都是大于根节点的,是右子树,如果后面的数中有小于 ...