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. 开源数字媒体资产管理系统:Razuna安装方法

    Razuna以一个使用Java语言编写的开源的数字媒体资产管理(Digital Asset Management)系统.在这里翻译一下它的安装步骤. Razuna包含以下版本: Razuna Stan ...

  2. Android 上滑上拉菜单SlidingDrawer 不全屏显示的方法

    这里来说一个已经被废弃的SlidingDrawer.. 他可以实现上拉,下拉的菜单. 但是有个问题就是上拉以后,是全屏显示的. 首先 写一个布局: <RelativeLayout xmlns:a ...

  3. 【翻译】Ext JS 5.0.1 中的新功能

    原文:What's New in Ext JS 5.0.1 今天,我们很高兴的宣布Ext JS 5.0.1发布了!此维护版本基于Sencha社区的反馈做了一些改进.下面让我们来了解一下这些改变. 可访 ...

  4. mysql语法、特殊符号及正则表达式的使用

    http://blog.csdn.net/pipisorry/article/details/46773545 sql语言 结构化的查询语言.(Structured Query Language),是 ...

  5. Android中使用SVG矢量图(一)

    SVG矢量图介绍 首先要解释下什么是矢量图像,什么是位图图像? 1.矢量图像:SVG (Scalable Vector Graphics, 可伸缩矢量图形) 是W3C 推出的一种开放标准的文本式矢量图 ...

  6. 【LaTeX排版】LaTeX论文排版<四>

    1.表格的插入     一般的表格插入的代码如下: \begin{table}[H] \centering \begin{tabular}{|c|c|c|} \hline 感知方法&优点&am ...

  7. EBS initialization parameters - Healthcheck

    APPLIES TO: Oracle EBS Applications Performance - Version 11.5.10.2 to 12.2 [Release 11.5.10 to 12.2 ...

  8. 【45】java的封装剖析

    类是构造对象的模板或蓝图. 封装的一些概念 从形式上看,封装不过是将数据和行为组合到一个包中,并对对象的使用者隐藏了数据的实现形式. 每个对象都包含实例域和方法.实例域的集合代表了一个集合的状态,通过 ...

  9. InvocationTargetException异常解析

    InvocationTargetException异常由Method.invoke(obj, args...)方法抛出.) { throw new ZeroException("参数不能小于 ...

  10. Linux系统下常用的快捷键

    快捷键 ctrl +  shift + '+'   将当前的终端放大 ctrl +  '-'           将当前的终端放小 ctrl +  l             清屏 ctrl +  u ...