MySql 基础篇

MySql 基础篇

MYSQL数据库

  • 启动与停止

win+r servieces.msc 服务 MySQL80 启动/停止
mysql默认开机自启
启 net start MySQL80
停 net stop MySQL80

  • 系统自带命令行链接客户端

需要配置PATH环境变量
mysql [-h 127.0.0.1] [-P 3306] -u root -p
-h 指链接的ip -p指链接的端口 可默认不改
-u指定用户root -p指定密码

SQL

SQL通用语法

  1. SQL可以单行或多行书写,以分号结尾。
  2. SQL可以通过空格和缩进增加可读性
  3. 不区分大小写

SQL分类

  1. DDL 数据定义语言 定义数据对象
  2. DML 数据操作语言 增删改查
  3. DQL 数据查询语言 查询表记录
  4. DCL 数据控制语言 创建数据库用户、控制数据库访问权限

DDL

  • 查询
    SHOW DATABASES;查询所有数据库
    SELECT DATABASE;查询当前数据库

  • 创建
    CREATE DATABASE [IF NOT EXISTS] 数据库名 [DEFAULT CHARSET 字符集(UTF8MB4 可省略)] [COLLATE 排序规则];

  • 删除
    DROP DATABASE [IF NOT EXISTS] 数据库名;

  • 使用
    USE 数据库名;

表操作-查询

SHOW TABLES;查询当前数据库所有表
DESC 表名;查询表结构
SHOW CREATE TABLE 表名;查询指定表语句

表操作-创建

CREATE TABLE 表名(
字段1 字段1类型[COMMENT 字段1注释],
字段2 字段2类型[COMMENT 字段2注释],
字段3 字段3类型[COMMENT 字段3注释],

字段N 字段N类型[COMMENT 字段N注释]
)[COMMENT 表注释];

表操作-数据类型

MYSQL支持的数据很多,主要分为三类:数值类型,字符产类型,日期时间类型。

数据类型

分类数据类型大小有字符(SIGNED)范围无字符(UNSIGNED)范围描述
TINYINT1 byte(-128,127)(0,255)小整数值
SMALLINT2 bytes(-32768,32767)(0,65535)大整数值
MEDIUMINT3 bytes(-8388608,8388607)(0,16777215)大整数值
数值类型INT或INTEGER4 bytes(2147483648,2147483647)(0,4294967295)极大整数值
BIGINT8 bytes--------------------------------------单精度浮点值
FLOAT4 bytes--------------------------------------双精度浮点值
DOUBLE8 bytes--------------------------------------小数值(精确定点数)
DECIMAL------------------------------------------依赖于M(精度)和D(标度)的值 依赖于M(精度)和D(标度)的值
-------------------------------------------------------------------------------------
CHAR----------------------------------------------定义长字符 char(10) 性能好
VARCHAR----------------------------------------------变长字符 varchar(10) 性能较差
TINYBLOB----------------------------------------------不超过255个字符的二进制数据
TINYTEXT----------------------------------------------短文本字符串
字符串类型BLOB----------------------------------------------长文本数据
TEXT----------------------------------------------二进制形式的中等长文本数据
MEDIUMTETX----------------------------------------------中等长度的文本数据
LONGBLOB----------------------------------------------二进制数据的极大文本数据
LONGTEXT----------------------------------------------极大文本数据
-------------------------------------------------------------------------------------
DATE3-------------------------------日期值
TIME3-------------------------------时间值或持续时间值
日期类型YEAR1-------------------------------年份值
DATETIME8-------------------------------混合日期和时间值
TIMESTAMP4-------------------------------混合日期和时间值,时间值截止至2038
表操作-修改
  • 添加字段
    ALTER TABLE 表名 ADD 字段名 类型(长度)[COMMENT 注释] [约束];

  • 修改数据类型
    ALTER TABLE 表名 MODIFY 字段名 新数据类型(长度);

  • 修改字段名和字段类型
    ALTER TABLE 表名 CHANGE 旧字段名 类型(长度) [COMMENT 注释] [约束];

  • 删除字段
    ALTER TABLE 表名 DROP 字段名;

  • 修改表名
    ALTER TABLE 表名 RENAME TO 新表名;

表操作-删除
  • 删除表
    DROP TABLE [IF EXISTS] 表名;

  • 删除指定表,并重新创建该表(清空!!!)
    TRUNCATE TABLE 表名;

DML

  • 对数据库中的表记录进行增删改操作

  • 添加数据 INSERT

  • 修改数据 UPDATE

  • 删除数据 DELETE

添加数据
  • 给指定字段添加数据
    INSERT INTO 表名(字段名1,字段2,…)VALUES(值1,值2,…);

  • 给全部字段添加数据
    INSTERT INTO 表名 VALUES (值1,值2,…);

  • 批量添加数据
    INSERT INTO 表名 (字段名1,字段2,…) VALUES(值1,值2,…),(值1,值2,…),(值1,值2,…);
    INSERT INTO 表名 VALUES(值1,值2,…),(值1,值2,…),(值1,值2,…),(值1,值2,…);

表操作-修改

UPDATE 表名 SET 字段名1 = 值1,…[where 条件];

删除

DELETE FROM 表名 [WHERE 条件];

DQL

select 字段列表
from 表名列表
where 条件列表
group by 分组字段列表
having 分组后的条件列表
order by 排序字段列表
limit 分页参数

DQL-基本查询
  1. 查询多个字段
    select 字段1,字段2,…from 表名;
    select * from 表名;

  2. 设置别名
    select 字段1[as 别名1],字段2[as 别名2],… from表名

  3. 去除重复记录
    select distinct 字段列表 from 表名;

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要在MySQL数据库中存储圆形要素,需要使用空间数据类型和空间函数。 MySQL支持几种空间数据类型,包括POINT、LINESTRING、POLYGON、MULTIPOINT、MULTILINESTRING、MULTIPOLYGON和GEOMETRYCOLLECTION。其中,圆形可以用POLYGON类型来表示。一个简单的圆形可以表示为一个由多边形组成的正多边形,多边形的边数越多,表示的圆形越接近圆形。 例如,以下代码创建了一个圆形的多边形: ``` SET @center = GeomFromText('POINT(116.397428 39.90923)'); SET @radius = 1000; SET @poly = CONCAT('POLYGON((', X(@center) + @radius * COS(RADIANS(45)),' ', Y(@center) + @radius * SIN(RADIANS(45)),',', X(@center) + @radius * COS(RADIANS(135)),' ', Y(@center) + @radius * SIN(RADIANS(135)),',', X(@center) + @radius * COS(RADIANS(225)),' ', Y(@center) + @radius * SIN(RADIANS(225)),',', X(@center) + @radius * COS(RADIANS(315)),' ', Y(@center) + @radius * SIN(RADIANS(315)),',', X(@center) + @radius * COS(RADIANS(45)),' ', Y(@center) + @radius * SIN(RADIANS(45)),'))'); ``` 在MySQL中,可以使用空间函数进行圆形的操作,例如计算两个圆形之间的距离、判断一个点是否在圆形内等。 以下是一个例子,计算一个点是否在圆形内: ``` SET @center = GeomFromText('POINT(116.397428 39.90923)'); SET @radius = 1000; SET @point = GeomFromText('POINT(116.383668 39.902188)'); SELECT Contains( GeomFromText(CONCAT('POLYGON((', X(@center) + @radius * COS(RADIANS(45)),' ', Y(@center) + @radius * SIN(RADIANS(45)),',', X(@center) + @radius * COS(RADIANS(135)),' ', Y(@center) + @radius * SIN(RADIANS(135)),',', X(@center) + @radius * COS(RADIANS(225)),' ', Y(@center) + @radius * SIN(RADIANS(225)),',', X(@center) + @radius * COS(RADIANS(315)),' ', Y(@center) + @radius * SIN(RADIANS(315)),',', X(@center) + @radius * COS(RADIANS(45)),' ', Y(@center) + @radius * SIN(RADIANS(45)),' ))'), @point ); ``` 如果返回值为1,则表示点在圆形内,否则不在。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

有事没事 敲代码

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

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

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

打赏作者

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

抵扣说明:

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

余额充值