新建用户

CREATE USER 'username'@'host' IDENTIFIED BY 'password';

[host 中 使用 % 为通配符, 匹配任意远程主机]

赋权

GRANT privileges ON databasename.tablename TO 'username'@'host' ;

privileges [select / insert / update / delete / drop * ]

查看用户

select * from mysql.user

插入

insert [table] values (xxx,xxx);

ALTER TABLE的使用

       //主要设置默认值,速度块

ALTER TABLE [tablename] ALTER COLUMN [columname] set default 5;

ALTER TABLE [tablename] ALTER COLUMN [columname] drop default;

//重命名、列类型、位置修改

ALTER TABLE [tablename] CHANGE COLUMN [oldcolumn] [newcolumn] varchar(32) NOT NULL FIRST;

ALTER TABLE [tablename] CHANGE COLUMN [oldcolumn] [newcolumn] varchar(32) NOT NULL AFTER contents;

//列类型、位置修改

ALTER TABLE [tablename] MODIFY COLUMN [newcolumn] varchar(32) NOT NULL AFTER contents;

unixtime

select unix_timestamp("2013-10-10 23:00:00");   // 1381417200

select from_unixtime(1381417200);                    //2013-10-10 23:00:00

datetime

对于字段的时间加减date_add()

set @dt = now();

select date_add(@dt, interval 1 day); -- add 1 day
select date_add(@dt, interval 1 hour); -- add 1 hour
select date_add(@dt, interval 1 minute); -- ...
select date_add(@dt, interval 1 second);
select date_add(@dt, interval 1 microsecond);
select date_add(@dt, interval 1 week);
select date_add(@dt, interval 1 month);
select date_add(@dt, interval 1 quarter);
select date_add(@dt, interval 1 year);

插入重复则更新

INSERT ON DUPLICATE KEY UPDATE语法是原子操作,效率和语法都非常之优美.

SELECT year,month,BIT_COUNT(BIT_OR(1<<day)) AS days FROM t1 GROUP BY year,month;

bit_count函数 计算出二进制中1的个数        //例如      10->1010      bit_count(10) = 2

外键约束的几种行为

  • cascade方式 在父表上update/delete记录时,同步update/delete掉子表的匹配记录 On delete cascade从mysql3.23.50开始可用; on update cascade从mysql4.0.8开始可用
  • set null方式 在父表上update/delete记录时,将子表上匹配记录的列设为null 要注意子表的外键列不能为not null On delete set null从mysql3.23.50开始可用; on update set null从mysql4.0.8开始可用
  • No action方式 如果子表中有匹配的记录,则不允许对父表对应候选键进行update/delete操作 这个是ANSI SQL-92标准,从mysql4.0.8开始支持
  • Restrict方式 同no action, 都是立即检查外键约束    . Set default方式 解析器认识这个action,但Innodb不能识别,不知道是什么意思...      注意:trigger不会受外键cascade行为的影响,即不会解发trigger

修改外键约束

alter table news drop foreign key news_ibfk_1;

alter table news add constraint news_ibfk_1 foreign key(owner_id) references user(UUID) on update cascade on delete cascade;

if使用

if(condition,expr2,expr3)

如果condition为真,返回expr2,否则返回expr3。

IFNULL(expr1,expr2)

假如expr1不为NULL,返回expr1,否则返回expr2。

CASE column WHEN arg THEN data [WHEN arg2 THEN data2] ELSE ndata END AS alias

当column为arg时,显示data[...],都不匹配显示ndata。

show VARIABLES LIKE 'AUTOCOMMIT';

设置启用或者禁用自动提交

set SESSION TRANSACTION ISOLATION LEVEL READ COMMITED;

可以设置4种隔离级别

查看MySQL性能时使用的命令

  • SHOW GLOBAL STATUS
  • SHOW ENGINE INNODB STATUS
  • SHOW FULL PROCESSLIST

转置字段(默认使用','分割)

select group_concat(column_a) where group_by column_b;

mysql版sql助记的更多相关文章

  1. 全国省市级联数据sql语句 mysql版

    全国省市级联数据sql语句 mysql版 --省级 provincial create table provincial ( provincialID int, provincialName ), p ...

  2. SQL优化 MySQL版 - B树索引详讲

    SQL优化 MySQL版  - -B树索引详讲 作者:Stanley 罗昊 [转载请注明出处和署名,谢谢!] 为什么要进行SQL优化呢?很显然,当我们去写sql语句时: 1会发现性能低 2.执行时间太 ...

  3. SQL优化 MySQL版 -分析explain SQL执行计划与笛卡尔积

    SQL优化 MySQL版 -分析explain SQL执行计划 作者 Stanley 罗昊 [转载请注明出处和署名,谢谢!] 首先我们先创建一个数据库,数据库中分别写三张表来存储数据; course: ...

  4. SQL优化 MySQL版 - 索引分类、创建方式、删除索引、查看索引、SQL性能问题

    SQL优化 MySQL版  - 索引分类.创建方式.删除索引.查看索引.SQL性能问题 作者 Stanley 罗昊 [转载请注明出处和署名,谢谢!] 索引分类 单值索引 单的意思就是单列的值,比如说有 ...

  5. 金蝶KIS&K3助记码SQL数据库批量刷新

    金蝶KIS&K3助记码SQL数据库批量刷新 用的次数不多,就没有写入存储过程或者触发里面了,可以自行实现. 第一步选择对应账套的数据库,执行下面的命令,这个是一个函数. go if exist ...

  6. sql语句练习50题(Mysql版-详加注释)

    表名和字段 1.学生表       Student(s_id,s_name,s_birth,s_sex) --学生编号,学生姓名, 出生年月,学生性别 2.课程表       Course(c_id, ...

  7. 常用的PHP数据库操作方法(MYSQL版)

    常用的PHP数据库操作方法(MYSQL版) 作者: 字体:[增加 减小] 类型:转载 时间:2011-06-08   最近一直在折腾自己的网站首页,写的大部分PHP脚本都要用到和MYSQL数据库相关的 ...

  8. Oracle、MySql、Sql Server比对

    1.    价格 MySql:廉价(部分免费):当前,MySQL採用双重授权(DualLicensed),他们是GPL和MySQLAB制定的商业许可协议.假设你在一个遵循GPL的自由(开源)项目中使用 ...

  9. Oracle 助记

    title: Oracle 助记 Nothing is impossible! 基础操作 $ sqlplus name/pssword; # 登录数据库 $ create user username ...

随机推荐

  1. Android开发中出现cannot be resolved to a variable错误,也就是R文件不能生成。

    最近开始学过习Android开发,配置完成开发环境后,在创建第一个Android项目就出现了cannot be resolved to a variable错误,也就是R文件不能生成的问题. 以下是从 ...

  2. 无法在web服务器上启动调试,此项目在使用一个被配置为使用特定IP地址的网站。请在项目URL中指定计算机名称。

    解决方案:IIS服务器管理-default web site 绑定-选择使用的IP-编辑-IP地址:全部未匹配

  3. linux 命令大全

    工作了一段时间,开始整理资料,好记性不如烂笔头啊. linux命令大全下载路径: 1.http://www.pc6.com/SoftView/SoftView_28912.html 2.http:// ...

  4. [转]IOS Segment页面之间view的切换

    有三个view,分别为view1.view2.view3,通过UISegmentedControl进行三个view的切换. @interface UIViewDemoViewController :  ...

  5. 【转】使用Boost Graph library(二)

    原文转自:http://shanzhizi.blog.51cto.com/5066308/942972 让我们从一个新的图的开始,定义一些属性,然后加入一些带属性的顶点和边.我们将给出所有的代码,这样 ...

  6. 手工部署Sqlserver CLR程序集

    原文 手工部署Sqlserver CLR程序集 以前一直用VS部署Sqlserver CLR程序集简单省事,现在服务器部署在内网了,必须手动更新部署Sqlserver CLR程序集.    开始以为A ...

  7. HDOJ 1253 胜利大逃亡(bfs)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1253 思路分析:因为问题需要寻找到达终点的最短的距离(最短的步数),即在状态转换图上需要找出层次最浅的 ...

  8. 关于PagedDataSource分页属性与DataSet和DataTable详解

    Asp.net提供了三个功能强大的列表控件:DataGrid.DataList和Repeater控件,但其中只有DataGrid控件提供分页功能.相对DataGrid,DataList和Repeate ...

  9. BZOJ 2748 音量调节

           这道题我开始做时想用搜索来做,但是失败了,后来仔细一想发现这就是一个背包问题,之后一切就简单多了.        代码如下: #include<cstdio> #includ ...

  10. BZOJ 1692: [Usaco2007 Dec]队列变换( 贪心 )

    数据 n <= 30000 , 然后 O( n² ) 的贪心也过了..... USACO 数据是有多弱啊 = = ( ps : BZOJ 1640 和此题一模一样 , 双倍经验 ) ------ ...