开源数据库Mysql_DBA运维实战 (DDL语句)

DDL

DDL语句 数据库定义语言:数据库、表、视图、索引、存储过程.

例如:CREATE DROP ALTER


DDL库

定义库{

创建业务数据库:CREAATE DATABASE 数据库名 ;

数据库名要求{

a.区分大小写

b.唯一性

c.不能使用关键字如 create select

d.不能单独使用数字和特殊符号"如-"

e.正常的:用拼音或单词即可。

}

查看所有数据库: SHOW DATABASES;

}

选择/进入数据库{

USE 数据库名_;

调用函数,查询当前库 SELECT database();

}

删除数据库: DROP DATABASE 数据库名_;

在Linux系统中的位置:(数据库的实体) /var/lib/mysql/


数据类型

数值类型:

常用: 整数类型 int , smallint , mediumint , blgint ,tinyint

浮点数类型(小数) float , double

定点数类型 DEC

位类型 BIT

无符号 UNSIGNED

测试

LAB1:(int,tinyint的最大值)

前言:TINYINT有符号型最大127

INT有符号型最大2147483647

a.创建一个表

sql 复制代码
mysql> create table test1( 
    tinyint_test tinyint,
   int_test int
  );

b.查询表结构

sql 复制代码
mysql> desc test1;
+--------------+------------+------+-----+---------+-------+
| Field        | Type       | Null | Key | Default | Extra |
+--------------+------------+------+-----+---------+-------+
| tinyint_test | tinyint(4) | YES  |     | NULL    |       | 
| int_test     | int(11)    | YES  |     | NULL    |       | 
+--------------+------------+------+-----+---------+-------+
2 rows in set (0.01 sec)

c.插入合法数值

sql 复制代码
mysql> insert into test1 values (111,111);
Query OK, 1 row affected (0.09 sec)
sql 复制代码
mysql> insert into test1(int_test) values(2147483647);
Query OK, 1 row affected (0.05 sec)

d.插入非法数值

sql 复制代码
错误的示例:
mysql> insert into test1(tinyint_test) values(128);
ERROR 1264 (22003): Out of range value for column 'tinyint_test' at row 1
正确的示例:
mysql> insert into test1(tinyint_test) values(127);
sql 复制代码
mysql> insert into test1(int_test) values(2147483648);
ERROR 1264 (22003): Out of range value for column 'int_test' at row 1

LAB2:(无符号unsigned)

前言: 数值无符号,就只能输入正值,不能输入负值

a.创建一个表

sql 复制代码
mysql> create table test2(
 tinyint_test tinyint unsigned,		      
int_test int unsigned
);
Query OK, 0 rows affected (0.00 sec)

b.查询表结构

sql 复制代码
mysql> desc test2;
+--------------+---------------------+------+-----+---------+-------+
| Field        | Type                | Null | Key | Default | Extra |
+--------------+---------------------+------+-----+---------+-------+
| tinyint_test | tinyint(3) unsigned | YES  |     | NULL    |       | 
| int_test     | int(10) unsigned    | YES  |     | NULL    |       | 
+--------------+---------------------+------+-----+---------+-------+
2 rows in set (0.00 sec)

c.插入合法数据

sql 复制代码
mysql> insert into test2(tinyint_test) values(255);
Query OK, 1 row affected (0.06 sec)
sql 复制代码
mysql> insert into test2(int_test) values(2147483648);
Query OK, 1 row affected (1.87 sec)

d.插入非法数据

sql 复制代码
mysql> insert into test2 values(-20,-20);
ERROR 1264 (22003): Out of range value for column 'tinyint_test' at row 1

LAB3:(零填充zerofill)

前言: zerofill 自动填充0

a.创建一个表

sql 复制代码
mysql> create table t2 (
 id1 int zerofill,
id2 int(6) zerofill
);
Query OK, 0 rows affected (0.05 sec)

b.查询表结构

sql 复制代码
mysql> desc t2;
+-------+---------------------------+------+-----+---------+-------+
| Field | Type                      | Null | Key | Default | Extra |
+-------+---------------------------+------+-----+---------+-------+
| id1   | int(10) unsigned zerofill | YES  |     | NULL    |       |
| id2   | int(6) unsigned zerofill  | YES  |     | NULL    |       |
+-------+---------------------------+------+-----+---------+-------+
2 rows in set (0.00 sec)

c.插入数据

sql 复制代码
mysql> insert into t2 values(2,2);
Query OK, 1 row affected (0.01 sec)

d.查询表内容

sql 复制代码
mysql> select * from t2;
+------------+--------+
| id1        | id2    |
+------------+--------+
| 0000000002 | 000002 |
+------------+--------+
1 row in set (0.00 sec)

字符串类型:

枚举类型:ENUM 有65536个元素

时间和日期类型:

在MySQL数据库中,我们可以使用字符串来存储时间,但是如果我们需要基于时间字段
进行查询操作(查询在某个时间段内的数据)就不便于查询实现

常用: DATE TIME DATETIME

约束类型


DDL表

**创表的目的:**a.表是数据库存储数据的基本单位

b.表由若干个字段(列)组成

c.主要是用来存储数据记录(行)

实例:

1.创建表

要求 创建库school

创建表student1

语法

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

sql 复制代码
mysql> CREATE  DATABASE school;#创建数据库school
            
mysql> use school; #使用库
          
mysql> create table student1(  id int, name varchar (20) , sex enum('m','f'), age int );# 创建一个表,四列

Query OK, 0 rows affected (0.03 sec)

2.查看表名

sql 复制代码
 mysql> show tables;     查看表名(需要进入一个数据库)
+------------------+
| Tables_in_school |
+------------------+
| student1         |
+------------------+
1 row in set (0.00 sec)
       

3.表中插入内容

语法

insert into 表名 values(字段值列表...);

sql 复制代码
 插入数据
        insert into student1 values (1,'zhangsan','m',33) ,
        insert into student1 values (2,'lisi','f',20) ,
        insert into student1 values (1,'wangwu','m',40) ,

4.查看表内容

sql 复制代码
 mysql> select * from student1;    查询表中所有字段的值

5.查看表结构

sql 复制代码
 desc student1;

注意表结构和表内容是两个概念。

相关推荐
Paraverse_徐志斌2 小时前
MySQL 线上大表 DDL 如何避免锁表(pt-online-schema-change)
数据库·mysql·ddl·mysql锁·锁表·pt-osc
哈哈幸运3 小时前
MySQL运维三部曲初级篇:从零开始打造稳定高效的数据库环境
linux·运维·数据库·mysql·性能优化
愚公搬代码3 小时前
【愚公系列】《Python网络爬虫从入门到精通》055-Scrapy_Redis分布式爬虫(安装Redis数据库)
数据库·爬虫·python
pwzs3 小时前
深入浅出 MVCC:MySQL 并发背后的多版本世界
数据库·后端·mysql
大熊猫今天吃什么4 小时前
【一天一坑】空数组,使用 allMatch 默认返回true
前端·数据库
双叶8364 小时前
(51单片机)LCD显示数据存储(DS1302时钟模块教学)(LCD1602教程)(独立按键教程)(延时函数教程)(I2C总线认识)(AT24C02认识)
c语言·数据库·单片机·嵌入式硬件·mongodb·51单片机·nosql
XY.散人4 小时前
初识Redis · C++客户端list和hash
数据库·redis·缓存
码上飞扬5 小时前
深入 MySQL 高级查询:JOIN、子查询与窗口函数的实用指南
数据库·mysql
海洋与大气科学5 小时前
【matlab】地图上的小图
开发语言·数据库·matlab
Geek__19926 小时前
Sqlite3交叉编译全过程
jvm·数据库·sqlite