mysql表中数据之和_mysql数据库之表和库

SQL:语句主要用于存储数据,查询数据,更新数据和管理关系数据库系统SQL语言有IBM开发,sql语言分为3中类型:

1.DDL语句 数据库定义语句:数据库,表,视图,索引,存储过程,例如create,drop,alter

2.DML语句 数据库操作语句:插入数据INSERT,删除数据DELETE,更新数据UPDATE,查询数据SELECT

3.DCL语句 数据库控制语句: 例如控制用户的访问权限GRANT,REVOKE

1. 操作文件夹(库)

增:create database db1 charset utf8;

查:show databases;

改:alter database db1 charset latin1;

删除: drop database db1;2. 操作文件(表)

先切换到文件夹下:use db1

增:create table t1(id int,name char);

查:show tables;

改:alter table t1 modify name char(3);

alter table t1 change name name1 char(2);

删:drop table t1;3. 操作文件中的内容(记录)

增:insert into t1 values(1,'egon1'),(2,'egon2'),(3,'egon3');

查:select* fromt1;

改:update t1 set name='sb' where id=2;

删:deletefrom t1 where id=1;

清空表:

deletefrom t1; #如果有自增id,新增的数据,仍然是以删除前的最后一样作为起始。

truncate table t1;数据量大,删除速度比上一条快,且直接从零开始,*auto_increment 表示:自增*primary key 表示:约束(不能重复且不能为空);加速查找

创建表

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

create table 表名(

字段名1 类型[(宽度) 约束条件],

字段名2 类型[(宽度) 约束条件],

字段名3 类型[(宽度) 约束条件]

);#注意:

1. 在同一张表中,字段名是不能相同2. 宽度和约束条件可选3. 字段名和类型是必须的

语法

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

mysql>create database staff;

Query OK,1 row affected (0.00sec)

mysql>use staff;

Database changed

mysql> create table staff_info (id int,name varchar(50),age int(3),sex enum('male','female'),phone bigint(11),job varchar(11));

Query OK, 0 rows affected (0.02sec)

mysql>show tables;+-----------------+

| Tables_in_staff |

+-----------------+

| staff_info |

+-----------------+

1 row in set (0.00sec)

mysql>desc staff_info;+-------+-----------------------+------+-----+---------+-------+

| Field | Type | Null | Key | Default | Extra |

+-------+-----------------------+------+-----+---------+-------+

| id | int(11) | YES | | NULL | |

| name | varchar(50) | YES | | NULL | |

| age | int(3) | YES | | NULL | |

| sex | enum('male','female') | YES | | NULL | |

| phone | bigint(11) | YES | | NULL | |

| job | varchar(11) | YES | | NULL | |

+-------+-----------------------+------+-----+---------+-------+

6 rows in set (0.00sec)

mysql> select id,name,sex fromstaff_info;

Empty set (0.00sec)

mysql> select * fromstaff_info;

Empty set (0.00 sec)

建表

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

mysql> insert into staff_info (id,name,age,sex,phone,job) values (1,'Alex',83,'female',13651054608,'IT');

Query OK,1 row affected (0.00sec)

mysql> insert into staff_info values (2,'Egon',26,'male',13304320533,'Teacher');

Query OK,1 row affected (0.00sec)

mysql> insert into staff_info values (3,'nezha',25,'male',13332353222,'IT'),(4,'boss_jin',40,'male',13332353333,'IT');

Query OK,2 rows affected (0.00sec)

Records:2Duplicates: 0 Warnings: 0

mysql> select * fromstaff_info;+------+----------+------+--------+-------------+---------+

| id | name | age | sex | phone | job |

+------+----------+------+--------+-------------+---------+

| 1 | Alex | 83 | female | 13651054608 | IT |

| 2 | Egon | 26 | male | 13304320533 | Teacher |

| 3 | nezha | 25 | male | 13332353222 | IT |

| 4 | boss_jin | 40 | male | 13332353333 | IT |

+------+----------+------+--------+-------------+---------+

4 rows in set (0.00 sec)

插入数据

查看表结构

查看表结构的两种方式:

describe:这种方式和desc:效果相同,可以查看当前表结构

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

mysql>describe staff_info;+-------+-----------------------+------+-----+---------+-------+

| Field | Type | Null | Key | Default | Extra |

+-------+-----------------------+------+-----+---------+-------+

| id | int(11) | YES | | NULL | |

| name | varchar(50) | YES | | NULL | |

| age | int(3) | YES | | NULL | |

| sex | enum('male','female') | YES | | NULL | |

| phone | bigint(11) | YES | | NULL | |

| job | varchar(11) | YES | | NULL | |

+-------+-----------------------+------+-----+---------+-------+

6 rows in set (0.00sec)

mysql>desc staff_info;+-------+-----------------------+------+-----+---------+-------+

| Field | Type | Null | Key | Default | Extra |

+-------+-----------------------+------+-----+---------+-------+

| id | int(11) | YES | | NULL | |

| name | varchar(50) | YES | | NULL | |

| age | int(3) | YES | | NULL | |

| sex | enum('male','female') | YES | | NULL | |

| phone | bigint(11) | YES | | NULL | |

| job | varchar(11) | YES | | NULL | |

+-------+-----------------------+------+-----+---------+-------+

6 rows in set (0.00sec)

mysql>show create table staff_info\G;*************************** 1. row ***************************Table: staff_info

Create Table: CREATE TABLE `staff_info` (

`id` int(11) DEFAULT NULL,

`name` varchar(50) DEFAULT NULL,

`age` int(3) DEFAULT NULL,

`sex` enum('male','female') DEFAULT NULL,

`phone` bigint(11) DEFAULT NULL,

`job` varchar(11) DEFAULT NULL

) ENGINE=InnoDB DEFAULT CHARSET=utf81 row in set (0.01sec)

ERROR:

No query specified

查看表结构

修改表结构

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1. 修改表名

ALTER TABLE 表名

RENAME 新表名;2. 增加字段

ALTER TABLE 表名

ADD 字段名 数据类型 [完整性约束条件…],

ADD 字段名 数据类型 [完整性约束条件…];3. 删除字段

ALTER TABLE 表名

DROP 字段名;4. 修改字段

ALTER TABLE 表名

MODIFY 字段名 数据类型 [完整性约束条件…];

ALTER TABLE 表名

CHANGE 旧字段名 新字段名 旧数据类型 [完整性约束条件…];

ALTER TABLE 表名

CHANGE 旧字段名 新字段名 新数据类型 [完整性约束条件…];5.修改字段排列顺序/在增加的时候指定字段位置

ALTER TABLE 表名

ADD 字段名 数据类型 [完整性约束条件…] FIRST;

ALTER TABLE 表名

ADD 字段名 数据类型 [完整性约束条件…] AFTER 字段名;

ALTER TABLE 表名

CHANGE 字段名 旧字段名 新字段名 新数据类型 [完整性约束条件…] FIRST;

ALTER TABLE 表名

MODIFY 字段名 数据类型 [完整性约束条件…] AFTER 字段名;

语法

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

create table t(id int unique,name char(10) notnull);#去掉null约束

alter table t modify name char(10) null;#添加null约束

alter table t modify name char(10) notnull;#去掉unique约束

alter table t drop index id;#添加unique约束

alter table t modify id int unique;

alter处理null和unique约束

alter操作非空和唯一

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

1、首先创建一个数据表table_test:

create table table_test(

`id` varchar(100) NOT NULL,

`name` varchar(100) NOT NULL,

PRIMARY KEY (`name`)

);2、如果发现主键设置错了,应该是id是主键,但如今表里已经有好多数据了,不能删除表再重建了,仅仅能在这基础上改动表结构。

先删除主键

alter table table_test drop primary key;

然后再增加主键

alter table table_test add primary key(id);

注:在增加主键之前,必须先把反复的id删除掉。

alter操作主键

8f900a89c6347c561fdf2122f13be562.png

961ddebeb323a10fe0623af514929fc1.png

创建press表

CREATE TABLE `press` (

`id` int(11) NOT NULL,

`name` char(10) DEFAULT NULL,

PRIMARY KEY (`id`)

) ;

创建book表

CREATE TABLE `book` (

`id` int(11) DEFAULT NULL,

`bk_name` char(12) DEFAULT NULL,

`press_id` int(11) NOT NULL,

KEY `press_id` (`press_id`)

) ;

解释:

CONSTRAINT symbol:可以给这个外键约束起一个名字,有了名字,以后找到它就很方便了。如果不加此参数的话,系统会自动分配一个名字。

FOREIGN KEY:将从表中的字段1作为外键的字段。

REFERENCES:映射到主表的字段2。

ON DELETE后面的四个参数:代表的是当删除主表的记录时,所做的约定。-------on delete cascade 级联删除(删除这个表接连的表也会删除)-------on update cascade 级联更新

RESTRICT(限制):如果你想删除的那个主表,它的下面有对应从表的记录,此主表将无法删除。

CASCADE(级联):如果主表的记录删掉,则从表中相关联的记录都将被删掉。

SET NULL:将外键设置为空。

NO ACTION:什么都不做。

注:一般是RESTRICT和CASCADE用的最多。

为book表添加外键

alter table book add constraint fk_id foreign key(press_id) references press(id);

删除外键

alter table book drop foreign key fk_id;

为表添加外键

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值