加入收藏 | 设为首页 | 会员中心 | 我要投稿 草根网 (https://www.0555zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 教程 > 正文

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

发布时间:2022-12-02 12:39:32 所属栏目:教程 来源:
导读:  SQL:语句主要用于存储数据,查询数据,更新数据和管理关系数据库系统SQL语言有IBM开发,sql语言分为3中类型:

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

  2.DML
  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;数据量大mysql数据表,删除速度比上一条快,且直接从零开始,*auto_increment 表示:自增*primary key 表示:约束(不能重复且不能为空);加速查找
 
  创建表
 
  create table 表名(
 
  字段名1 类型[(宽度) 约束条件],
 
  字段名2 类型[(宽度) 约束条件],
 
  字段名3 类型[(宽度) 约束条件]
 
  );#注意:
 
  1. 在同一张表中,字段名是不能相同2. 宽度和约束条件可选3. 字段名和类型是必须的
 
  语法
 
  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)
 
  建表
 
  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:效果相同,可以查看当前表结构
 
  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_infoG;*************************** 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
 
  查看表结构
 
  修改表结构
 
  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 字段名;
 
  语法
 
  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操作非空和唯一
 
  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操作主键
 
  创建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;
 
  为表添加外键
 

(编辑:草根网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!