02-25 Mysql 基础语法

-- sql 语法
-- DDL(数据定义语言)
-- DML(数据操作语言 )
-- DCL(数据控制语言)
-- --注意:sql中大小写不敏感(大写和小写是一样的),每条sql语句以分号结束

-- 一.DDL -主要提供数据库和表的创建、删除和修改

-- 0.删除数据库
drop DATABASE school;; --直接删除指定数据库
drop DATABASE if EXISTS school;
-- --如果指定的数据库存在删除数据库

-- 1.创建数据库
-- 直接创建数据库
create database school;
-- 当指定数据库不存在创建数据库
CREATE DATABASE if NOT EXISTS school2;
-- 支持中文
create database if not exists school default CHARSET utf8;

-- 2.使用/切换数据库 :use 数据库名
use school2;

-- 3.新建表 create table 表名(字段名1 类型1,字段名2 类型2。。。)
-- 注意:a.表名一般需要加前缀’t'或者‘tb’ b.字段用来确定表中存储哪些数据,字段名随便命名,但不能是关键字。c.数据类型必须是mysql支持的数据类型

-- 常用数据类型:int 定长字符串char(size) 不定长字符串varchar(size) 无约束字符串text
create table t_student(stuid int,stuname varchar(20),gender bit,birth date);

-- create table 表名(字段名1 类型1,字段名2 类型2。。。)
-- 常用的约束:not null --不能为空 default-- 默认值 unique --值唯一 primary KEY - 主键约束
-- 主键约束:指的是表中能够唯一标识一条记录的字段(通过主键值能够找到表中唯一一行记录。)
-- 注意:一个字段可以添加多个约束,多个约束之间用空格隔开
create table t_student(
-- auto_increment 自动增长,只针对primary key有效,并且primary key的类型是int
stuid int not null auto_increment,
stuname varchar(20) not null,
gender bit default 1 ,
birth date,
-- 设置primary key 为stuid,设置一个字段为主键,其实间接约束了当前字段的值唯一
primary key(stuid));

-- 4.删除表:drop table if exists
-- 清空表:truncate table (不能使用if exists)
drop table if exists t_student;
truncate table t_student;

-- 5.修改表(主要是添加字段和删除字段(列))
-- 5.1 添加字段(列) alter table 表名 add column 字段名 字段类型 约束
alter table t_student add column scores float(5,2) default 0;
-- 5.2 删除字段 alter table 表名 drop column 字段名
alter table t_student drop column gender;

-- 二。DML 数据操作语言 -主要针对数据库中的数据增删改查
-- 1.增(添加数据/记录)
-- 1.1 插入数据/记录 insert into 表名 values(值1,值2,值3。。。) 依次给指定表中的字段赋值
insert into t_student values(103,'xiaoming',0,'2010-9-8'),(2,'xiaohua',0,'1994-3-4'),(102,'xiaohong',0,'1998-9-10');

-- 1.2 插入数据/记录
-- insert into 表名(字段1,字段2) values(值1,值2) 依次给指定表中的指定字段赋值,约束为not null的字段必须写

insert into t_student(stuname,birth) values('lisi','1991-10-20');

-- 值的问题:sql中数字对应的值直接写,字符串要使用引号引起,单双引号都可以,bit 类型的值只有0/1,时间可以用内容是满足时间格式的字符串,也可以是通过通过时间函数获取的值

-- 时间函数:now() -当前时间
-- select now(); -结果显示当前 年月日 时分秒
-- select date(now()); -获取当前日期
-- SELECT year/month/day/hour/minute/second(now);

-- 2.删(删除数据/记录)
-- 2.1 delete from 表名; --删除指定表的所有记录
delete from t_student;

-- 2.2 delete from 表名 where 条件语句 --删除满足条件的记录
-- SQL中的条件语句:=(判断是否相等) <>(不等于,和Python中的!=功能一样,> , < ,>= ,<=)
delete from t_student where stuid=1;
delete from t_student where stuid<100;

-- 3.改(修改数据/记录)
-- update 表名 set 字段1=新值1,字段2=新值2。。;
-- 将指定表中的指定字段/列的全部值赋值为新值
update t_student set gender=1;

-- update 表名 set 字段1=新值1,字段2=新值2。。 where 条件语句
-- 将指定表中的满足条件的行的值赋值为新值
update t_student set gender=0 where stuname='xiaohua' or stuname='xiaohong ';
-- 通配符% : 表示任意个数的任意字符,包括0个
-- 通配符_ : 表示一个任意字符
update t_student set birth='2000-01-01' where stuname like 'xiao%';
-- 通配符_ : 表示一个任意字符
update t_student set birth='2000-12-12' where stuname like 'lis_';
-- 注意:通配符只对字符串有效

-- 4 查(获取数据)
-- 4.11 select * from 表名 -直接查询,获取指定表中所有数据
select * from t_student;

-- 4.12 select 字段名1,字段名2。。。from 表名 -获取指定表中所有行中指定的列
select stuname,stuid from t_student ;

-- 4.13 select 字段名1,字段名2。。。 from 表名 where 条件语句
-- 获取指定表中满足条件的行的指定字段
select stuname,stuid from t_student where stuname like 'xiao%';

-- 4.2 列/字段重命名
-- select 字段1 as 新字段1,字段2 as 新字段2.。。from 表名,as可以省略
select stuid,stuname,gender as '性别' from t_student;

-- 4.3 对查询结果赋值(一般针对布尔数据 bit)
-- select if (字段名,值1,值2) from 表名;
-- 查询指定字段,并且判断字段和对应的值是0还是1,如果是1取值1,如果是0取值2
-- 这里的if用法是Mysql专有的,别的数据库不能使用
select if(gender,'男','女') as '性别' from t_student;
-- 通用写法
select case gender when 1 then '男' else '女' end as '性别' from t_student;

-- 4.4 对列进行合并运算
-- select concat(字段1,字段2。。。) from 表名;
-- 注意:bit类型(布尔)的数据不能合并,数字和字母可以合并
select concat (stuname,':',stuid) as 'name_id' from t_student ;

-- 4.5 模糊查询
-- 查询时通过like条件来指定查询对象
-- sql 支持逻辑运算符and / or / not
select * from t_student where stuname like '%i%' and not stuid<102;

-- 4.6 排序(先查询再排序)
-- select * from 表名 order by 字段
-- 对查询结果按照指定字段的值进行升序排序
-- select * from 表名 order by 字段 esc --升序
-- select * from 表名 order by 字段 desc --降序

select * from t_student order by gender;
select * from t_student order by stuid desc;

-- 先按性别升序排序,再按学号降序排序,写在前面的字段优先级高
select * from t_student order by gender,stuid desc;

-- 4.7 限制
-- select * from 表名 limit N - 获取查询结果中的前n条数据
select * from t_student limit 3;

-- select * from 表名 limit M offset N -对查询结果跳过前N条数据往后取M条数据
select * from t_student limit 3 offset 4; -跳过前4条数据去3条数据

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容

  • 一、数据库简介 1.数据库系统 1.1数据库 DataBase【DB】,指的是长期保存到计算机上的数据,按照一定顺...
    郑元吉阅读 588评论 0 6
  • MYSQL 基础知识 1 MySQL数据库概要 2 简单MySQL环境 3 数据的存储和获取 4 MySQL基本操...
    Kingtester阅读 7,777评论 5 116
  • ORACLE自学教程 --create tabletestone ( id number, --序号usernam...
    落叶寂聊阅读 1,066评论 0 0
  • 理论知识 修改数据表 1.修改表名 格式:Alter table 旧表名 rename [to] 新表名; 如下:...
    lufaqiang阅读 1,429评论 0 0
  • 随风而散 梧桐落叶 散了谁的芳华 林间小道 见过多少渐行渐远的过路人 岁月带走苍老的年华 却也留下耐人寻味的足迹 ...
    七月听你阅读 173评论 0 0