// 1、展示所有的数据库,即使没有创建任何一个数据库,系统默认也会有四个数据库 SHOW DATABASES; // 2、选择数据库 mysql USE mysql; // 3、显示当前所选择的数据库 SELECT DATABASE(); // 4、如果不存在数据库 studySql 则创建 CREATE DATABASE IF NOT EXISTS `studySql`; // 5、如果存在数据库 studySql 则删除 DROP DATABASE IF EXISTS `studySql`;
1、字符串类型 char定义固定长度的字符串,长度在0-255之间,varchar定义可变长的字符串,长度在0到65535之间的值,text可存储更大的字符串 2、数字类型 数字分为整数、浮点数、精确到小数点的数 整数类型:INT, 浮点类型:FLOAT,DOUBLE, 精确数字:DECIMAL,NUMERIC 3、日期类型 (1) YEAR,格式如YYYY,只有年份,范围从 1901到2155,和 0000 (2) DATE,格式如YYYY-MM-DD,有年月日,范围从 ‘1000-01-01‘ 到 ‘9999-12-31‘ (3) DATATIME,格式如 YYYY-MM-DD hh:mm:ss,有年月日时分秒,范围从 ‘1970-01-01 00:00:01‘ 到‘2038-01-19 03:14:07‘ (4) DATASTAMP / TIMESTAMP,比DATATIME还要精确6位,格式如 YYYY-MM-DD hh:mm:ss.xxxxxx,
范围从‘1000-01-01 00:00:00.000000‘到‘9999-12-31 23:59:59.999999‘
以上的数据类型用于创建表时对字段进行补充,除了补充之外,还应该对字段有限制,比如用户的手机号码不可重复,用户要添加一个唯一的id值来表示其“身份”,这些限制就是表约束,我们通常有以下几种方式来对表进行约束
1、主键 主键代表唯一的值,如id,主键不可重复,也不可以为空,用字段 PRIMARY KEY 来表示 2、唯一键 不可重复,但允许为空,比如手机号码,用字段UNIQUE来表示 3、AUTO_INCREMENT 当我们没有给某一字段设置值的时候,希望它自动增长,需要数据类型为数字类型 4、NOT NULL 不允许为空 5、DEFAULT 设置默认值 6、外键在下一篇关于DQL的总结中具体说明~
有了以上的概念,我们就可以在数据库中创建一张“用户表”了
CREATE TABLE IF NOT EXISTS `person` ( id INT PRIMARY KEY AUTO_INCREMENT, name VARCHAR(20) , telephone VARCHAR(20) UNIQUE NOT NULL, birth TIMESTAMP )
在这张表里插入、删除、修改一些数据
// 给每一个字段一一对应设置值 INSERT INTO `person` VALUES (9, ‘judy‘, ‘18877776666‘, ‘1998-08-08‘); INSERT INTO `person` VALUES (10, ‘kiki‘, ‘18012345678‘, ‘2000-08-10‘); // id 可自增、birth设置默认参数 INSERT INTO `person` (name, telephone) VALUES (‘alice‘, ‘15600000000‘); // 修改数据 UPDATE `person` SET NAME = ‘xiaoming‘ WHERE id = 10; // 删除元素 DELETE FROM `person` WHERE id = 9; // 清空表所有内容 DELETE FROM `person` // 查询表里所有数据 SELECT * FROM `person` // 删除表 DROP TABLE IF EXISTS `person`
部分sql语句执行的结果如下图所示
// 修改表名(将表名person改为users) ALTER TABLE `person` RENAME TO `users`; // 修改表字段(将telephone修改为phone,数据类型为varchar) ALTER TABLE `users` CHANGE telephone phone VARCHAR(20); // 修改表数据类型(将birth的类型修改为Data,默认值为当前时间) ALTER TABLE `users` MODIFY DATATIME DEFAULT CURRENT_TIMESTAMP; // 增加列 gender ALTER TABLE `users` ADD gender varchar(10); ALTER TABLE `user` ADD updateTime TIMESTAMP; // 删除列 ALTER TABLE `user` DELETE updateTime; // 查看表结构 DESC `users`
// 根据表结构创建另外一个表(复制) CREATE TABLE `user1` LIKE `users` // 根据另外一个表中的所有内容(不包括表结构), 创建新的表 CREATE TABLE `user3` AS (SELECT * FROM `user`) // 查看创建表的sql语句 SHOW CREATE TABLE `users`
以上就是mysql的基本概念以及基本操作,关于 DQL( Data Query Language),数据查询的部分总结在下一篇文章中~
原文:https://www.cnblogs.com/vigourice/p/15145390.html