create database 数据库名;

drop database 数据库名;

use 数据库名;

create table table_name ( column_name, column_type ); //创建表
//column_type
/**
* 数值、日期/时间和字符串 三大类型
* 数值 范围
tinyint (-128, 127)
smallint (-32 768,32 767)
mediumint (-8 388 608,8 388 607)
int\integer (-2 147 483 648,2 147 483 647)
bigint (-9 233 372 036 854 775 808,9 223 372 036 854 775 807)
float (-3.402 823 466 E+38,-1.175 494 351 E-38),0,(1.175 494 351 E-38,3.402 823 466 351 E+38)
double (-1.797 693 134 862 315 7 E+308,-2.225 073 858 507 201 4 E-308),0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308)
* 字符串
char 0-255字节 定长字符串
varchar 0-65535 字节 变长字符串
tinyblob 0-255字节 不超过 255 个字符的二进制字符串
tinytext 0-255字节 短文本字符串
blob 0-65 535字节 二进制形式的长文本数据
text 0-65 535字节 长文本数据
mediumblob 0-16 777 215字节 二进制形式的中等长度文本数据
mediumtext 0-16 777 215字节 中等长度文本数据
longblob 0-4 294 967 295字节 二进制形式的极大文本数据
longtext 0-4 294 967 295字节 极大文本数据
*/

drop table table_name; 删除表

修改某一条数据
update student set sex='男' where id=4;

删除数据
delete from student where id=5;

insert into table_name (对应的列表名称) values (对应的值); 向表中添加数据
//多条数据擦汗如的话 需用逗号把值隔开
例如: insert into table_name (对应的列表名称) values (对应的值),(对应的值),(对应的值) ;

select 列名儿/星号(多个,逗号隔开) from 表名儿; 查询数据

select 列名儿/星号(多个,逗号隔开) from 表名儿 where (过滤条件) and (链接其他条件) // or (选择过滤);

select 列名儿/星号(多个,逗号隔开) from 表名儿 where (过滤条件) like '%含有的字符%' and (链接其他条件) // or (选择过滤);
//引号必须要加
//百分号就相当于 任意字符串 中间是要过滤的字符 可以理解为 含有****字符

select 列表名儿 from 表名儿 union all / union select 列表名儿 from 表名儿;
union // 链接两个或多个语句 输入到一个返回结果中 且 返回的结果 不重复
union all // 链接的后的结果全部显示出来 不去重

select * from 表名 order by 列名(,逗号隔开,可以有多个) asc(升序) / desc(降序);

select 列名 from 表名 group by 列名;
可以用到的聚合函数有 avg(求平均值) sum(求和) count(记数) max(最大) min(最小)
count 可以结合 having 语句来实现删除重复数据
select count(*) from table_name group by (列表名) having > 1;

select 列名 from 表名 group by 列名 with rollup;
在 合并分组的基础上继续 求出总和

select coalesce(列名, '代替的名字') from 表名 group by 列名 with rollup;
基于 rollup 计算得来的 综合 名字一般 为 null
coalesce(name, '总数') means: 将名字为空的name, 也就是最后一行计算的总和的名字 改为 总数。
此处 如果名字不为空 则不能替换 只能替换为null的

链表查询

<inner join 选择的是公共部分> 这里可以用
select a.列名,b.列名(选择任何你想要的列数据(注意 此处是两个表的数据都可以的)) from 表名 a(代替名) inner join 表名 b(代替名,和前面一致) on a.列表名 = b.列表名;

<left join> 左表里的所有数据会被查询出来 右表无数据对应 显示的null
select a.列名,b.列名(选择任何你想要的列数据(注意 此处是两个表的数据都可以的)) from 表名 a(代替名) left join 表名 b(代替名,和前面一致) on a.列表名 = b.列表名;

<right join> 右表里的所有数据会被查询出来 右表无数据对应 显示的null
select a.列名,b.列名(选择任何你想要的列数据(注意 此处是两个表的数据都可以的)) from 表名 a(代替名) right join 表名 b(代替名,和前面一致) on a.列表名 = b.列表名;

查询表中某字段为空/不为空的值
select * from 表名 where 列表名 is null;
select * from 表名 where 列表名 is not null;

正则查找
select * from 表名 where 列表名 REGEXP '正则规则';

对存在的数据库表进行增删改;

alter table 表名 add 列名 该列类型 (可以跟 first / after 列名 表示插入列的位置);

alter table 表名 drop 列名;

alter table 表名 modify 列名 字段类型; //只修改字段类型
alter table 表名 modify 表名 修改的类型 not null default 100;

alter table 表名 change 表名 修改后的表名 对应的类型; //连着表名一起修改

修改字段默认值(只有修改默认值的时候用到alter)
alter table 表名 alter 表名 set default 1000;

修改数据库表名
alter table 表名 以前的名字=修改后的名字;

防止数据重复
建表的时候设置
指定字段 primary key(主键) 或者 unique(唯一) 索引

如果我们设置了唯一索引,那么在插入重复数据时,SQL语句将无法执行成功,并抛出错。
insert ignore into //插入的数据如果重复,就忽略插入的数据,数据库中保留 老数据

读取数据的时候 过滤重复数据
select distinct 列名 from 表名; / 使用 group by 来处理

建立新的表格 来存储 不重复的数据
create table table_name select 列表名 from 表名 group by (要获取的列表名);

查询第i条以后到第j条的数据(不包括第i条)
//两个数字
select * from student limit 2,5; 显示从第三条数据开始显示五条数据

//一个数字的时候
select * from student limit 3; 获取前三条数据;

mysql 基础语法掌握~ This is just the beginning.的更多相关文章

  1. MYSQL基础语法的使用

    喜欢的朋友可以关注下,粉丝也缺. MYSQL介绍 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品.MySQL 是最流行的关系型数据库管理系统之 ...

  2. MYSQL从入门到放弃系列:mysql基础语法

    Mysql基本语法 启动MySQL net start mysql 连接与断开服务器 mysql -h 地址 -P 端口 -u 用户名 -p 密码 跳过权限验证登录MySQL mysqld --ski ...

  3. mysql基础语法之(全文索引)

    1.概要 InnoDB引擎对FULLTEXT索引的支持是MySQL5.6新引入的特性,之前只有MyISAM引擎支持FULLTEXT索引.对于FULLTEXT索引的内容可以使用MATCH()…AGAIN ...

  4. Mysql 基础语法1

    MySQL的软件架构 1.开启MySQL服务器:以windows服务的形式开启,在cmd下net startmysql|net stop mysql,在cmd下使用mysqld –default-fi ...

  5. 一. MySQL基础语法

    1. 案例库表 2. DQL语言(数据查询) 2.1 基础查询 -- 进入指定的库 USE myemployees; DESC employees; -- 使用SELECT查询字段 # 1.查询表中的 ...

  6. mysql基础语法及拓展到web中的sql注入

    本来是想写下javaweb的mvc(tomcat, spring, mysql)的搭建,  昨天搭到凌晨3点, 谁知道jdbcTemplate的jar包不好使, 想死的心都有了, 想想还是休息一下, ...

  7. mysql 基础语法

    以下为自己学习mysql 的一些笔记,以方便查询 目录 一. ALTER的 语法 二. 表的完整性约束 三. 索引的操作(mysql 数据库支持至少 16 个索引) 四. 视图的操作 五. 触发器的操 ...

  8. MySQL基础语法命令

    1. 建表 创建MySQL数据表需要以下信息: 表名 表字段名 定义每个表字段 通用语法: CREATE TABLE table_name (column_name column_type); 实例: ...

  9. Mysql基础语法-建库-建表(增、删、改、查、表关联及子查询)

    前言:MySQL是一个数据库管理系统,也是一个关系数据库.它是由Oracle支持的开源软件,MySQL可以在各种平台上运行UNIX,Linux,Windows等.可以将其安装在服务器甚至桌面系统上. ...

随机推荐

  1. python的w+到底是什么

    python 文件处理的打开方式有很多种, os.mknod("test.txt") 创建空文件 fp = open("test.txt",w) 直接打开一个文 ...

  2. (十二)UITableView的基本使用

    UITableView之所以支持滚动,是因为继承自UIScrollView.默认是垂直滚动,性能极佳. UITableView的两种样式: 1.UITableViewStylePlain       ...

  3. OpenCV特征点检测算法对比

    识别算法概述: SIFT/SURF基于灰度图, 一.首先建立图像金字塔,形成三维的图像空间,通过Hessian矩阵获取每一层的局部极大值,然后进行在极值点周围26个点进行NMS,从而得到粗略的特征点, ...

  4. 理解WebKit和Chromium: Chromium网络栈

    转载请注明原文地址:http://blog.csdn.net/milado_nju ## 概述 前面讲到Chromium的资源加载机制,在调用栈上,提到URLRequest之后就戛然而止,在这之下就是 ...

  5. Material Design之NavigationView和DrawerLayout实现侧滑菜单栏

    本文将介绍使用Google最新推出规范式设计中的NavigationView和DrawerLayout结合实现侧滑菜单栏效果,NavigationView是android-support-design ...

  6. 【一天一道LeetCode】#17. Letter Combinations of a Phone Number

    一天一道LeetCode (一)题目 Given a digit string, return all possible letter combinations that the number cou ...

  7. PS图层混合算法之二(线性加深,线性减淡,变亮,变暗)

    线性加深模式: 查看每个通道的颜色信息,通过降低"亮度"使底色的颜色变暗来反映绘图色,和白色混合没变化. Linear Burn 线形加深 C=A+B-1 如果上下层的像素值之和小 ...

  8. 物理引擎中velocity的单位是个什么鬼?

    现在, 你可能对于什么是velocity的单位感到奇怪.他是单位秒中经过点的一个可测量的量(pt/s).如果你想要在iphone横屏从左往右的移动物体,并且你想在1秒内移动1024个点,那么物体的x速 ...

  9. S3c2440A WINCE平台HIVE注册表+binfs的实现

    今天最大的收获莫过于把binfs和hive注册表同时在三星的平台上实现了,这可是前无古人啊(只是看到好多哥们说找不到三星的HIVE资料),哈哈哈.怕今天的成果日后成炮灰,还是写下来比较好,要养成这样的 ...

  10. java--jdk api中其他对象(System,Runtime,Calendar,Math,Random,Date)

    转载请申明出处:http://blog.csdn.net/xmxkf/article/details/9796729 day18-01-其他对象(System) SystemDemo java.lan ...