当前位置: 首页 > news >正文

做网站 技术国内最新新闻摘抄

做网站 技术,国内最新新闻摘抄,网站推广软件工具,安徽康东建设工程有限公司网站文章目录 文章简介演示库表创建数据库表选择数据库删除数据库创建表删除表向表中插入数据更新数据删除数据查询数据WHERE 操作符聚合函数LIKE 子句分组 GROUP BY HAVINGORDER BY(排序) 语句LIMIT 操作符 分页查询多表查询-联合查询 UNION 操作符多表查询-连接的使用-JOIN语句编…

文章目录

    • 文章简介
    • 演示库表
    • 创建数据库表
    • 选择数据库
    • 删除数据库
    • 创建表
    • 删除表
    • 向表中插入数据
    • 更新数据
    • 删除数据
    • 查询数据
    • WHERE 操作符
    • 聚合函数
    • LIKE 子句
    • 分组 GROUP BY + HAVING
    • ORDER BY(排序) 语句
    • LIMIT 操作符 分页查询
    • 多表查询-联合查询 UNION 操作符
    • 多表查询-连接的使用-JOIN
    • 语句编写和底层执行顺序

文章简介

本文主要介绍了MySQL核心命令的介绍和使用方法。

演示库表

mmall_learning库表结构。
在这里插入图片描述
部分命令中涉及的其他库表,均为简单说明,可不必在意具体表结构。

创建数据库表

CREATE DATABASE 数据库名;

CREATE DATABASE mmall_learning;

列出 MySQL 数据库管理系统的数据库列表。

SHOW DATABASES;

结果如下:
在这里插入图片描述

选择数据库

USE 数据库名;

USE mmall_learning;

显示指定数据库的所有表,使用该命令前需要使用 use 命令来选择要操作的数据库。
SHOW TABLES:
在这里插入图片描述
显示数据表的属性,属性类型,主键信息 ,是否为 NULL,默认值等其他信息。

SHOW COLUMNS FROM 数据表;

例如:展示购物车的数据表结构

SHOW COLUMNS FROM mmall_cart;

结果如下:
在这里插入图片描述

删除数据库

1.直接删除数据库,不检查是否存在

DROP DATABASE 数据库;

2.删除数据库,如果存在的话

DROP DATABASE IF EXISTS 数据库;

创建表

CREATE TABLE table_name (column1 datatype,column2 datatype,...
);

示例:

CREATE TABLE `mmall_cart` (`id` int(11) NOT NULL AUTO_INCREMENT,`user_id` int(11) NOT NULL,`product_id` int(11) DEFAULT NULL COMMENT '商品id',`quantity` int(11) DEFAULT NULL COMMENT '数量',`checked` int(11) DEFAULT NULL COMMENT '是否选择,1=已勾选,0=未勾选',`create_time` datetime DEFAULT NULL COMMENT '创建时间',`update_time` datetime DEFAULT NULL COMMENT '更新时间',PRIMARY KEY (`id`),KEY `user_id_index` (`user_id`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=146 DEFAULT CHARSET=utf8;

解释:
~如果你不想字段为空可以设置字段的属性为 NOT NULL,如上实例中的 id 与 user_id 字段,在操作数据库时如果输入该字段的数据为空,就会报错。
~AUTO_INCREMENT 定义列为自增的属性,一般用于主键,数值会自动加 1。
~PRIMARY KEY 关键字用于定义列为主键。 您可以使用多列来定义主键,列间以逗号 , 分隔。
~ENGINE 设置存储引擎,CHARSET 设置编码。
~UNIQUE KEY 唯一约束,是指所有记录中字段的值不能重复出现。例如,为 user_id 字段加上唯一性约束后,每条记录的 user_id 值都是唯一的,不能出现重复的情况。

删除表

1.删除表,如果存在的话

DROP TABLE IF EXISTS 数据表;

2.直接删除表,不检查是否存在

DROP TABLE 数据表;

向表中插入数据

INSERT INTO table_name (column1, column2, column3, ...) VALUES (value1, value2, value3, ...);

table_name 是你要插入数据的表的名称。
column1, column2, column3, … 是表中的列名。
value1, value2, value3, … 是要插入的具体数值。

示例:
向以下表mmall_cart中再插入一行数据
在这里插入图片描述

INSERT INTO `mmall_cart` VALUES ('126', '21', '26', '1', '1', '2017-04-13 21:27:06', '2017-04-13 21:27:06');

在这里插入图片描述

更新数据

UPDATE table_name
SET column1 = value1, column2 = value2, ...
WHERE condition;

示例:
在这里插入图片描述
将上表中的user_id/product_id均改为20

UPDATE mmall_cart SET user_id = '20', product_id = '20' WHERE id = 126;

结果如下:
在这里插入图片描述

删除数据

DELETE FROM table_name
WHERE condition;

在这里插入图片描述
删除id为127的数据

DELETE FROM mmall_cart WHERE id = 127;

结果为:
在这里插入图片描述

查询数据

SELECT column1, column2, ...
FROM table_name
[WHERE condition]
[ORDER BY column_name [ASC | DESC]]
[LIMIT number];

简单示例:

-- 选择所有列的所有行
SELECT * FROM users;-- 选择特定列的所有行
SELECT username, email FROM users;-- 添加 WHERE 子句,选择满足条件的行
SELECT * FROM users WHERE is_active = TRUE;-- 添加 ORDER BY 子句,按照某列的升序排序
SELECT * FROM users ORDER BY birthdate;-- 添加 ORDER BY 子句,按照某列的降序排序
SELECT * FROM users ORDER BY birthdate DESC;-- 添加 LIMIT 子句,限制返回的行数
SELECT * FROM users LIMIT 10;-- 使用 AND 运算符和通配符
SELECT * FROM users WHERE username LIKE 'j%' AND is_active = TRUE;-- 使用 OR 运算符
SELECT * FROM users WHERE is_active = TRUE OR birthdate < '1990-01-01';-- 使用 IN 子句
SELECT * FROM users WHERE birthdate IN ('1990-01-01', '1992-03-15', '1993-05-03');

WHERE 操作符

有条件地从表中选取数据,可将 WHERE 子句添加到 SELECT 语句中。WHERE 子句用于在 MySQL 中过滤查询结果,只返回满足特定条件的行。
示例:

SELECT * FROM users WHERE username = 'test';

常搭配的逻辑符号有

说明符号
不等于<>, !=
等于=
大于>
小于<
大于等于>=
小于等于<=

聚合函数

语法:

SELECT 聚合函数(字段列表) FROM 表名;

示例表:
在这里插入图片描述
COUNT计数,结果为4

SELECT COUNT(quantity) FROM mmall_cart;

MAX求最大值,结果为9

SELECT MAX(quantity) FROM mmall_cart;

MIN求最小值,结果为1

SELECT MIN(quantity) FROM mmall_cart;

AVG求平均值,结果为4.25

SELECT AVG(quantity) FROM mmall_cart;

SUM求和,结果为17

SELECT SUM(quantity) FROM mmall_cart;

LIKE 子句

LIKE 子句是在 MySQL 中用于在 WHERE 子句中进行模糊匹配的关键字。
示例:

SELECT * FROM customers WHERE last_name LIKE 'S%';

以上 SQL 语句将选择所有姓氏以 ‘S’ 开头的客户。

分组 GROUP BY + HAVING

GROUP BY 语句根据一个或多个列对结果集进行分组。一般配合聚合函数和HAVING使用。
WHERE和HAVING的区别是HAVING可以对分组后的数据进行过滤。

语法:

SELECT 字段列表 FROM 表名 [WHERE 条件] GROUP BY 分组字段名 [HAVING 分组后过滤条件];

示例:
查询年龄小于45的员工,并根据工作地址分组,获取同一地址员工数量大于等于3的工作地址

SELECT workaddress, COUNT(*) FROM emp WHERE age < 45 GROUP BY workaddress HAVING COUNT(*) >= 3;

ORDER BY(排序) 语句

ORDER BY(排序) 语句可以按照一个或多个列的值进行升序(ASC)或降序(DESC)排序。
语法:

SELECT column1, column2, ...
FROM table_name
ORDER BY column1 [ASC | DESC], column2 [ASC | DESC], ...;

示例:

SELECT * FROM mmall_cart ORDER BY user_id;

数据就会按给定字段排序,结果如下:
在这里插入图片描述

LIMIT 操作符 分页查询

语法

SELECT 字段列表 FROM 表名 LIMIT 起始索引, 查询记录数

在这里插入图片描述
示例:
查询第一页员工数据,每页展示十条记录

SELECT * FROM emp LIMIT 10;

多表查询-联合查询 UNION 操作符

UNION:连接数据集关键字,可以将两个查询结果集拼接为一个,会过滤掉相同的记录
UNION ALL:连接数据集关键字,可以将两个查询结果集拼接为一个,不会过滤掉相同的记录
注意:对于联合查询的多张表列数必须保持一致,字段类型也需要保持一致。
作用简单描述就是:表A有a/b两列20条数据,表B有a/b两列30条数据,通过UNION ALL以后可以得到a/b两列50条数据。使用UNION后,会获得不重复的a/b两列数据

语法:

SELECT 字段列表 FROM 表A ...
UNION [ALL]
SELECT 字段列表 FROM 表B ...;

示例,查询 product_id>15,quantity<5的数据
在这里插入图片描述

SELECT * FROM mmall_cart WHERE product_id > 18
UNION
SELECT * FROM mmall_cart WHERE quantity > 6;

查询结果为
在这里插入图片描述
说明,第一条SELECT可以查询出后两条数据,第二条SELECT语句可以查询出第二条数据,拼一起后即为原表后三条数据。

多表查询-连接的使用-JOIN

JOIN用于联合多表查询,其中:
INNER JOIN(内连接,或等值连接):获取两个表中字段匹配关系的记录。
LEFT JOIN(左连接):获取左表所有记录,即使右表没有对应匹配的记录。
RIGHT JOIN(右连接): 与 LEFT JOIN 相反,用于获取右表所有记录,即使左表没有对应匹配的记录。


在这里插入图片描述


以下 以员工表emp,部门表dept为例来简单说明。每个部门有对应的多个员工,属于1对N。

内连接

语法:

SELECT column1, column2, ...
FROM table1
INNER JOIN table2 ON table1.column_name = table2.column_name;

内连接分为隐式和显示连接。对于显示内连接,inner可以省略。


在这里插入图片描述


左连接和右连接
语法:

SELECT column1, column2, ...
FROM table1
LEFT JOIN table2 ON table1.column_name = table2.column_name;
SELECT column1, column2, ...
FROM table1
RIGHT JOIN table2 ON table1.column_name = table2.column_name;

在这里插入图片描述


自连接
自连接是表与自身表相连接


在这里插入图片描述


语句编写和底层执行顺序

语句编写顺序
在这里插入图片描述
示例:

SELECT DISTINCT column1, column2
FROM table1
JOIN table2 ON table1.id = table2.foreign_id
WHERE column1 > 100
GROUP BY column1
HAVING COUNT(*) > 1
ORDER BY column1 DESC
LIMIT 10;

MySQL语句底层的执行顺序如下:

1. FROM子句:选择数据来源的表或视图。
2. ON子句:连接条件(如果有的话,例如在JOIN操作中)。
3. JOIN子句:如果有的话,执行连接操作。
4. WHERE子句:过滤条件,只返回符合条件的记录。
5. GROUP BY子句:分组统计的字段。
6. HAVING子句:分组后的过滤条件。
7. SELECT子句:选取特定的列。
8. DISTINCT子句:去除重复数据。
9. ORDER BY子句:结果集的排序顺序。
10. LIMIT子句:限制结果集的数量。

文章转载自:
http://gaffer.hwLk.cn
http://attitude.hwLk.cn
http://tesseract.hwLk.cn
http://malm.hwLk.cn
http://chiengmai.hwLk.cn
http://platinocyanic.hwLk.cn
http://sapraemia.hwLk.cn
http://copasetic.hwLk.cn
http://cowlstaff.hwLk.cn
http://disclamation.hwLk.cn
http://regulate.hwLk.cn
http://adumbrative.hwLk.cn
http://myalism.hwLk.cn
http://arcuate.hwLk.cn
http://cooptative.hwLk.cn
http://hitachi.hwLk.cn
http://busiest.hwLk.cn
http://comicality.hwLk.cn
http://shool.hwLk.cn
http://isoleucine.hwLk.cn
http://dohc.hwLk.cn
http://excitonic.hwLk.cn
http://antitoxin.hwLk.cn
http://undesirable.hwLk.cn
http://behavioristic.hwLk.cn
http://sickroom.hwLk.cn
http://technolatry.hwLk.cn
http://ectoenzym.hwLk.cn
http://eyestone.hwLk.cn
http://counterview.hwLk.cn
http://pants.hwLk.cn
http://arousal.hwLk.cn
http://eburnation.hwLk.cn
http://playbus.hwLk.cn
http://appulsion.hwLk.cn
http://biomembrane.hwLk.cn
http://unpredictable.hwLk.cn
http://pipage.hwLk.cn
http://ikaria.hwLk.cn
http://recvee.hwLk.cn
http://quintillion.hwLk.cn
http://drool.hwLk.cn
http://corbeil.hwLk.cn
http://luxuriant.hwLk.cn
http://heresy.hwLk.cn
http://anthea.hwLk.cn
http://motet.hwLk.cn
http://urbanologist.hwLk.cn
http://endocarditis.hwLk.cn
http://detritivorous.hwLk.cn
http://quantity.hwLk.cn
http://thanedom.hwLk.cn
http://reporting.hwLk.cn
http://rejuvenesce.hwLk.cn
http://diphtherial.hwLk.cn
http://condole.hwLk.cn
http://metonic.hwLk.cn
http://limitr.hwLk.cn
http://truncate.hwLk.cn
http://viceroy.hwLk.cn
http://replevin.hwLk.cn
http://preservice.hwLk.cn
http://sepulcher.hwLk.cn
http://suboxide.hwLk.cn
http://pulque.hwLk.cn
http://brassy.hwLk.cn
http://dudheen.hwLk.cn
http://jinn.hwLk.cn
http://deluge.hwLk.cn
http://numbers.hwLk.cn
http://xanthone.hwLk.cn
http://ventose.hwLk.cn
http://gridiron.hwLk.cn
http://viridity.hwLk.cn
http://radii.hwLk.cn
http://cinquefoil.hwLk.cn
http://copier.hwLk.cn
http://amortization.hwLk.cn
http://catrigged.hwLk.cn
http://intellectual.hwLk.cn
http://luxe.hwLk.cn
http://lexan.hwLk.cn
http://runology.hwLk.cn
http://maxillary.hwLk.cn
http://mammonist.hwLk.cn
http://epurate.hwLk.cn
http://biographize.hwLk.cn
http://microbic.hwLk.cn
http://limerick.hwLk.cn
http://bowdrill.hwLk.cn
http://offertory.hwLk.cn
http://woodpie.hwLk.cn
http://illfare.hwLk.cn
http://beneficiary.hwLk.cn
http://umbones.hwLk.cn
http://republication.hwLk.cn
http://mimosa.hwLk.cn
http://endopleura.hwLk.cn
http://sexangular.hwLk.cn
http://rollicking.hwLk.cn
http://www.15wanjia.com/news/67875.html

相关文章:

  • 中国建设监理网站花都网站建设公司
  • 网站如何做电脑和手机软件浙江短视频seo优化网站
  • 网站如何排版seo网络优化日常工作内容
  • 中国人民银行广州分行门户网站东莞网络营销
  • 机械加工厂接单平台app百度seo排名优化教程
  • 建设银行东四十条支行支行网站建站推广
  • 怎么找网站帮我做推广大地资源网在线观看免费
  • 建设局查询网站网址域名ip解析
  • 安徽海外网络推广网站seo专员
  • seo提高网站排名百度推广后台
  • 做外贸的怎么建立自己的网站百度竞价点击神器下载安装
  • 网络工作室取名seo搜索引擎优化招聘
  • 游戏网站建设方案书武汉新闻最新消息
  • 一级域名做网站中国站长之家官网
  • 济南便宜网站设计刷推广链接
  • 江西建设单位网站河北百度推广
  • 网站开发工程师工资郑州手机网站建设
  • 网站费用单百度搜索引擎盘搜搜
  • 深圳网站制作工作室正规seo需要多少钱
  • 江阴做网站的企业网站推广公司排名
  • 企业b2c网站建设google play下载安装
  • 公司转让一般卖多少钱厦门seo推广
  • 婚恋网站模板凡科建站怎么建网站
  • 网站总体结构长沙网络公司营销推广
  • 上海做ui网站最好的公司西安优化网站公司
  • 想开网站怎样做整站seo优化
  • 电子招标投标平台网站建设互联网平台公司有哪些
  • 网站建设和网站推广海外推广代理商
  • php 快速网站开发seoshanghai net
  • 课程微网站开发技术搜索点击软件