mysql 数据库操作--create,alter,drop,show, 数据类型,char,vachar,init,float,date等

2.SQL语句可单行或多行书写,以“;”结尾

3.关键词不能跨多行或简写

4.用空格和缩进来提高语句的可读性

5.子句通常位于独立行,便于编辑,提高可读性

注释:

SQL标准:

/*注释内容*/ 多行注释

-- 注释内容 单行注释,注意有空格

MySQL注释:#

数据库对象


数据库的组件(对象):

数据库、表、索引、视图、用户、存储过程、函数、触发器、事件调度器等

命名规则:

1.必须以字母开头

2.可包括数字和三个特殊字符(# _ $

3.不要使用MySQL的保留字

4.同一database(Schema)下的对象不能同名

SQL语句分类


SQL语句分类:

DDL: Data Defination Language 数据定义语言

CREATE,DROP,ALTER

DML: Data Manipulation Language 数据操作语言

INSERT,DELETE,UPDATE

DCL:Data Control Language 数据控制语言(权限)

GRANT,REVOKE,COMMIT,ROLLBACK

DQL:Data Query Language 数据查询语言

SELECT

SQL语句构成


SQL语句构成:

Keyword组成clause(字句)

多条clause组成语句

示例:

SELECT * SELECT子句

FROM products FROM子句

WHERE price>400 WHERE子句

说明:一组SQL语句,由三个子句构成,SELECT,FROM和WHERE是关键字

一. 数据库操作

===========================================================================

utf8mb4编码比utf8多一个功能(支持字符—表情包等)

创建数据库

建议-----指定字符集


在创建数据库的时候指定好字符集—防止乱码

在/etc/my.cof 要重启服务

这里改的是服务端的字符集

在这里插入图片描述

指定客户端字符集

mysql --character-sets-dir=utf8md4

永久在/etc/my.cnf.d.mysql-clients.cnf

default-character-set=utf8mb4

在这里插入图片描述

1.创建数据库


CREATE DATABASE|SCHEMA [IF NOT EXISTS] ‘DB_NAME’;

CHARACTER SET 'character set name’COLLATE ‘collate name’

//没有指定编发格式

create database test2;

show create database test2;

//指定编码格式

create database test2 charater set utf8mb4;

show create database test2;

2.修改数据库:


ALTER DATABASE DB_NAME character set utf8;

3. 删除数据库


DROP DATABASE|SCHEMA [IF EXISTS] ‘DB_NAME’;

查看支持所有字符集:SHOW CHARACTER SET;

查看支持所有排序规则:SHOW COLLATION;

获取命令使用帮助:

mysql> HELP KEYWORD;

help create database 查看关键字帮助

4.查看数据库列表:


mysql> SHOW DATABASES;

二. 表:二维关系

============================================================================

默认表的字符格式,与数据库的格式一致

设计表:遵循规范

定义:字段,索引

字段:字段名,字段数据类型,修饰符

约束,索引:应该创建在经常用作查询条件的字段上

创建表CREATE TABLE

(1) 直接创建

(2) 通过查询现存表创建;新表会被直接插入查询而来的数据

CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name

[(create_definition,…)] [table_options] [partition_options] select_statement

(3) 通过复制现存的表的表结构创建,但不复制数据

CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name { LIKE

old_tbl_name | (LIKE old_tbl_name) }

注意:

Storage Engine是指表类型,也即在表创建时指明其使用的存储引擎,同一

库中不同表可以使用不同的存储引擎

同一个库中表建议要使用同一种存储引擎类型

CREATE TABLE [IF NOT EXISTS] ‘tbl_name’ (col1 type1 修饰符, col2 type2 修饰符, …)

字段信息

• col type1

• PRIMARY KEY(col1,…)

• INDEX(col1, …)

• UNIQUE KEY(col1, …)

表选项

• ENGINE [=] engine_name

SHOW ENGINES;查看支持的engine类型

• ROW_FORMAT [=]

{DEFAULT|DYNAMIC|FIXED|COMPRESSED|REDUNDANT|COMPACT}

获取帮助:mysql> HELP CREATE TABLE;

查看所有的引擎:SHOW ENGINES

查看表:SHOW TABLES [FROM db_name]

查看表结构:DESC [db_name.]tb_name

SHOW COLUMNS FROM [db_name.]tb_name

删除表:DROP TABLE [IF EXISTS] tb_name

看表创建命令:SHOW CREATE TABLE tbl_name

查看表状态:SHOW TABLE STATUS LIKE 'tbl_name’

查看库中所有表状态:SHOW TABLE STATUS FROM db_name

在这里插入图片描述

数据类型


MySql支持多种列类型:

数值类型

日期/时间类型

字符串(字符)类型

https://dev.mysql.com/doc/refman/5.5/en/data-types.html

在这里插入图片描述

char和vachar的区别:

char(4 )定长----只存4个字符 (不够补,多余砍掉)

宽度固定,规律

varchar(5 )变长-----可以变(少了节约空间,多了补充)

1、整型

tinyint(m) 1个字节 范围(-128~127)

smallint(m) 2个字节 范围(-32768~32767)

mediumint(m) 3个字节 范围(-8388608~8388607)

int(m) 4个字节 范围(-2147483648~2147483647)

bigint(m) 8个字节 范围(±9.22*10的18次方)

加了unsigned,则最大值翻倍

如:tinyint unsigned的取值范围为(0~255)

int(m)里的m是表示SELECT查询结果集中的显示宽度,并不影响实际的取值范

围,规定了MySQL的一些交互工具(例如MySQL命令行客户端)用来显示字符

的个数。对于存储和计算来说,Int(1)和Int(20)是相同的

  • 17
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值