建表属于DDL语句,包括create,drop,alter
create table 表名(字段名1 数据类型, 字段名2 数据类型,字段名3 数据类型,)
varchar:可变长度字符串,速度慢,节省空间
char:定长字符串,不管实际的数据长度是多少,分配固定长度的长度去存储数据,速度快,浪费空间
int(11):数字中的整数型
bigint:数字中的长整型
float:单精度浮点型数据
double:双精度浮点型数据
date:短日期类型
datetime:长日期类型
clob:字符大对象,最多可以存储4G字符串,超过255字符
blob:二进制大对象 ,专门用来存图片,声音,视频等流媒体数据。往BLOB类型的字段插入数据的时候,需要使用IO流
create table t_student(
no int,
name varchar(32),
sex char(1),
age int(3),
email varchar(255)
);
mysql> create table t_student(
-> no int,
-> name varchar(32),
-> sex char(1),
-> age int(3),
-> email varchar(255)
-> );
Query OK, 0 rows affected (0.01 sec)
drop table if exists t_student;
注:字段名和值要一一对应,数量要对应,数据类型要对应。
insert语句凡是执行成功了,那么必然会多一条记录。没有给其他字段指定值的话,默认值是null
mysql> insert into t_student (no,name,sex,age,email) values(1,'zhangsan','m',20,'[email protected]')
-> ;
Query OK, 1 row affected (0.01 sec)
mysql> select * from t_student;
+------+----------+------+------+------------------+
| no | name | sex | age | email |
+------+----------+------+------+------------------+
| 1 | zhangsan | m | 20 | [email protected] |
+------+----------+------+------+------------------+
1 row in set (0.00 sec)
create table t_student(
no int,
name varchar(32),
sex char(1) default 'm',
age int(3),
email varchar(255)
);
mysql> desc t_student;
+-------+--------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+--------------+------+-----+---------+-------+
| no | int(11) | YES | | NULL | |
| name | varchar(32) | YES | | NULL | |
| sex | char(1) | YES | | m | |
| age | int(3) | YES | | NULL | |
| email | varchar(255) | YES | | NULL | |
+-------+--------------+------+-----+---------+-------+
insert into t_student(no) values(1);
+------+------+------+------+-------+
| no | name | sex | age | email |
+------+------+------+------+-------+
| 1 | NULL | m | NULL | NULL |
+------+------+------+------+-------+
前面的字段名省略的话,等于都写上了!所以值也要都写上
mysql> insert into t_student values(2,'lisi','f',13,'123456');
mysql> select * from t_student;
+------+------+------+------+--------+
| no | name | sex | age | email |
+------+------+------+------+--------+
| 1 | NULL | m | NULL | NULL |
| 2 | lisi | f | 13 | 123456 |
+------+------+------+------+--------+
str_to_date:将字符串varchar类型转换成date类型
date_format:将date类型转换成具有一定格式的varchar字符串类型
drop table if exists t_user;
create table t_user(
id int,
name varchar(32),
birth date,
);
mysql> desc t_user;
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id | int(11) | YES | | NULL | |
| name | varchar(32) | YES | | NULL | |
| birth | date | YES | | NULL | |
+-------+-------------+------+-----+---------+-------+
注意:数据库中所有的标识符全部都是小写,单词和单词之间使用下划线进行衔接。
插入数据:
str_to_date:将字符串varchar类型转换成date类型,可以把varchar转换成date类型数据,通常使用在插入insert方面
如果提供的日期字符串是’1990-01-01’,不需要此函数。
语法格式:
str_to_date(‘字符串日期’,‘日期格式’)
mysql的日期格式:
%Y:年
%m: 月
%d: 日
%h: 时
%i: 分
%s: 秒
insert into t_user(id,name,birth) values(1,'zhangsan',str_to_date('01-10-1990','%d-%m-%Y'));
mysql> select * from t_user;
+------+----------+------------+
| id | name | birth |
+------+----------+------------+
| 1 | zhangsan | 1990-10-01 |
+------+----------+------------+
date_format:通常使用在查询日期方面。设置展示的日期格式。
select id,name,date_format(birth,'%m/%d/%Y') as birth from t_user;
+------+----------+------------+
| id | name | birth |
+------+----------+------------+
| 1 | zhangsan | 10/01/1990 |
+------+----------+------------+
drop table if exists t_user;
create table t_user(
id int,
name varchar(32),
birth date,
create_time datetime
);
mysql短日期默认格式:%Y-%m-%d
mysql长日期默认格式:%Y-%m-%d %h:%i:%s
insert into t_user(id,name,birth,create_time) values(1,'zhangsan','1990-01-01','2020-03-18 15:49:50');
mysql> select * from t_user;
+------+----------+------------+---------------------+
| id | name | birth | create_time |
+------+----------+------------+---------------------+
| 1 | zhangsan | 1990-01-01 | 2020-03-18 15:49:50 |
+------+----------+------------+---------------------+
用now()函数,并且获得的时间带有:时分秒信息,是datetime类型的
insert into t_user (id,name,birth,create_time) values(2,'lisi','1990-01-01',now());
mysql> select * from t_user;
+------+----------+------------+---------------------+
| id | name | birth | create_time |
+------+----------+------------+---------------------+
| 1 | zhangsan | 1990-01-01 | 2020-03-18 15:49:50 |
| 2 | lisi | 1990-01-01 | 2021-09-18 11:01:44 |
+------+----------+------------+---------------------+
语法格式:
update 表名 set 字段名1 = 值1,字段名2 = 值2,字段名3 = 值3...where 条件
update t_user set name = 'jack',birth = '2000-10-11' where id = 2;
mysql> select * from t_user;
+------+----------+------------+---------------------+
| id | name | birth | create_time |
+------+----------+------------+---------------------+
| 1 | zhangsan | 1990-01-01 | 2020-03-18 15:49:50 |
| 2 | jack | 2000-10-11 | 2021-09-18 11:01:44 |
+------+----------+------------+---------------------+
不加where则全部更新!
mysql> update t_user set name = 'jack',birth = '2000-10-11';
mysql> select * from t_user;
+------+------+------------+---------------------+
| id | name | birth | create_time |
+------+------+------------+---------------------+
| 1 | jack | 2000-10-11 | 2020-03-18 15:49:50 |
| 2 | jack | 2000-10-11 | 2021-09-18 11:01:44 |
+------+------+------------+---------------------+
语法格式:
delete from 表名 where 条件
delete from t_user where id = 2;
+------+------+------------+---------------------+
| id | name | birth | create_time |
+------+------+------------+---------------------+
| 1 | jack | 2000-10-11 | 2020-03-18 15:49:50 |
+------+------+------------+---------------------+
注意:没有条件,整张表的数据会全部删除