全部SQL源文件链接:https://pan.baidu.com/s/1wc51qkVetSRybFzcIYGBIg 提取码:3wpt
方式一:经典的插入
语法:insert into 表名(字段名,…) values(值,…);
特点
1、要求值的类型和字段的类型要一致或兼容;
2、字段的个数和顺序不一定与原始表中的字段个数和顺序一致但必须保证值和字段一一对应;
3、假如表中有可以为null的字段,注意可以通过以下两种方式插入null值
①字段和值都省略
②字段写上,值使用null
4、字段和值的个数必须一致
5、字段名可以省略,默认所有列
具体案例:
SELECT * FROM beauty; #1.插入的值的类型要与列的类型一致或兼容 INSERT INTO beauty(id,NAME,sex,borndate,phone,photo,boyfriend_id) VALUES(13,'唐艺昕','女','1990-4-23','1898888888',NULL,2); #2.不可以为null的列必须插入值。可以为null的列如何插入值? #方法一: INSERT INTO beauty(id,NAME,sex,borndate,phone,photo,boyfriend_id) VALUES(13,'唐艺昕','女','1990-4-23','1898888888',NULL,2); #方法二: INSERT INTO beauty(id,NAME,sex,phone) VALUES(15,'娜扎','女','1388888888'); #3.列的顺序是否可以调换 INSERT INTO beauty(NAME,sex,id,phone) VALUES('蒋欣','女',16,'110'); #4.列数和值的个数必须一致 INSERT INTO beauty(NAME,sex,id,phone) VALUES('关晓彤','女',17,'110'); #5.可以省略列名,默认所有列,而且列的顺序和表中列的顺序一致 INSERT INTO beauty VALUES(18,'张飞','男',NULL,'119',NULL,NULL);方式二语法:insert into 表名 set 列名=值,列名=值,…
INSERT INTO beauty SET id=19,NAME=‘刘涛’,phone=‘999’;
两种方式的区别
1.方式一支持一次插入多行,语法如下: insert into 表名【(字段名,..)】 values(值,..),(值,...),...; 2.方式一支持子查询,语法如下: insert into 表名 查询语句; #1、方式一支持插入多行,方式二不支持 INSERT INTO beauty VALUES(23,'唐艺昕1','女','1990-4-23','1898888888',NULL,2) ,(24,'唐艺昕2','女','1990-4-23','1898888888',NULL,2) ,(25,'唐艺昕3','女','1990-4-23','1898888888',NULL,2); #2、方式一支持子查询,方式二不支持 INSERT INTO beauty(id,NAME,phone) SELECT 26,'宋茜','11809866'; INSERT INTO beauty(id,NAME,phone) SELECT id,boyname,'1234567' FROM boys WHERE id<3;创建库
create database 【if not exists】 库名【 character set 字符集名】; #案例:创建库Books CREATE DATABASE IF NOT EXISTS books ;修改库
alter database 库名 character set 字符集名; #案例:更改库的字符集 ALTER DATABASE books CHARACTER SET gbk;删除库
drop database 【if exists】 库名; #案例:库的删除 DROP DATABASE IF EXISTS books;表的创建 ★
/* 语法: create table 表名( 列名 列的类型【(长度) 约束】, 列名 列的类型【(长度) 约束】, 列名 列的类型【(长度) 约束】, ... 列名 列的类型【(长度) 约束】 ) */ #案例:创建表Book CREATE TABLE book ( id INT, #编号 bName VARCHAR (20), #图书名 price DOUBLE, #价格 authorId INT, #作者编号 publishDate DATETIME#出版日期 ) ; DESC book; #案例:创建表author CREATE TABLE IF NOT EXISTS author ( id INT, au_n`author`ame VARCHAR (20), nation VARCHAR (10) ); DESC author ;表的修改
1.添加列 alter table 表名 add column 列名 类型 【first|after 字段名】; 2.修改列的类型或约束 alter table 表名 modify column 列名 新类型 【新约束】; 3.修改列名 alter table 表名 change column 旧列名 新列名 类型; 4 .删除列 alter table 表名 drop column 列名; 5.修改表名 alter table 表名 rename 【to】 新表名; 案例: #①修改列名 ALTER TABLE book CHANGE COLUMN publishdate pubDate DATETIME ; #②修改列的类型或约束 ALTER TABLE book MODIFY COLUMN pubdate TIMESTAMP; #③添加新列 ALTER TABLE author ADD COLUMN annual DOUBLE; #④删除列 ALTER TABLE book_author DROP COLUMN annual; #⑤修改表名 ALTER TABLE book_author RENAME TO author; DESC book;表的删除
drop table【if exists】 表名; 案例: DROP TABLE IF EXISTS book_author; SHOW TABLES; #通用的写法: DROP DATABASE IF EXISTS 旧库名; CREATE DATABASE 新库名 ; DROP TABLE IF EXISTS 旧表名; CREATE TABLE 表名();复制表
1、复制表的结构 create table 表名 like 旧表; 2、复制表的结构+数据 create table 表名 select 查询列表 from 旧表【where 筛选】; 案例 INSERT INTO author VALUES (1,'村上春树','日本'), (2,'莫言','中国'), (3,'冯唐','中国'), (4,'金庸','中国'); SELECT * FROM Author; SELECT * FROM copy2; #1.仅仅复制表的结构 CREATE TABLE copy LIKE author; #2.复制表的结构+数据 CREATE TABLE copy2 SELECT * FROM author; #只复制部分数据 CREATE TABLE copy3 SELECT id,au_name FROM author WHERE nation='中国'; #仅仅复制某些字段 CREATE TABLE copy4 SELECT id,au_name FROM author WHERE 0;整型
分类:
tinyint、smallint、mediumint、int/integer、bigint 1 2 3 4 8特点:
① 如果不设置无符号还是有符号,默认是有符号,如果想设置无符号,需要添加unsigned关键字② 如果插入的数值超出了整型的范围,会报out of range异常,并且插入临界值③ 如果不设置长度,会有默认的长度 长度代表了显示的最大宽度,如果不够会用0在左边填充,但必须搭配zerofill使用!案例
#1.如何设置无符号和有符号 DROP TABLE IF EXISTS tab_int ; CREATE TABLE tab_int (t1 INT (7) ZEROFILL, t2 INT (7) ZEROFILL) ; DESC tab_int ; INSERT INTO tab_int VALUES (- 123456) ; INSERT INTO tab_int VALUES (- 123456, - 123456) ; INSERT INTO tab_int VALUES (2147483648, 4294967296) ; INSERT INTO tab_int VALUES (123, 123) ; SELECT * FROM tab_int ;浮点型
定点数:dec(M,D);decimal(M,D)
浮点数:float(M,D) 4;double(M,D) 8
特点:
①M代表整数部位+小数部位的个数,D代表小数部位②如果超出范围,则报out or range异常,并且插入临界值③M和D都可以省略,但对于定点数,M默认为10,D默认为0④如果精度要求较高,则优先考虑使用定点数案例
#测试M和D DROP TABLE tab_float ; CREATE TABLE tab_float (f1 FLOAT, f2 DOUBLE, f3 DECIMAL) ; SELECT * FROM tab_float ; DESC tab_float ; INSERT INTO tab_float VALUES(123.4523,123.4523,123.4523); INSERT INTO tab_float VALUES(123.456,123.456,123.456); INSERT INTO tab_float VALUES(123.4,123.4,123.4); INSERT INTO tab_float VALUES(1523.4,1523.4,1523.4); #原则: #所选择的类型越简单越好,能保存数值的类型越小越好较短的文本:char、varchar
其他:
binary和varbinary用于保存较短的二进制enum用于保存枚举set用于保存集合较长的文本:text、blob(较大的二进制)
特点
写法 M的意思 特点 空间的耗费 效率 char char(M) 最大的字符数,可以省略,默认为1 固定长度的字符 比较耗费 高 varchar varchar(M) 最大的字符数,不可以省略 可变长度的字符 比较节省 低案例
CREATE TABLE tab_char( c1 ENUM('a','b','c') ); INSERT INTO tab_char VALUES('a'); INSERT INTO tab_char VALUES('b'); INSERT INTO tab_char VALUES('c'); INSERT INTO tab_char VALUES('m'); INSERT INTO tab_char VALUES('A'); SELECT * FROM tab_set; CREATE TABLE tab_set( s1 SET('a','b','c','d') ); INSERT INTO tab_set VALUES('a'); INSERT INTO tab_set VALUES('A,B'); INSERT INTO tab_set VALUES('a,c,d');分类:
date只保存日期;time 只保存时间;year只保存年;datetime保存日期+时间;timestamp保存日期+时间;特点
字节 范围 时区等的影响 datetime 8 1000——9999 不受 timestamp 4 1970-2038 受案例
CREATE TABLE tab_date( t1 DATETIME, t2 TIMESTAMP ); INSERT INTO tab_date VALUES(NOW(),NOW()); SELECT * FROM tab_date; SHOW VARIABLES LIKE 'time_zone'; SET time_zone='+9:00';