mysql声明摘要
前一段时间,和学生参加该项目的最终完成,主要的项目是做一个报告,它涉及到很多sql声明,因此,采取下一个汇总。
一、基金会
1.数据库相关的命令
a>.创建数据库
CREATE DATABASE 数据库名
b>.创建数据库并设置默认字符集
CREATE DATABASE 数据库名 DEFAULT CHARACTER SET utf8;
c>.删除数据库
DROP DATABASE 数据库名
2.数据表相关命令
a>.删除表
DROP TABLE 表名;
b>.新建表
DROP TABLE IF EXISTS 表名;
CREATE TABLE 表名 (
`id` INT NOT NULL AUTO_INCREMENT,
`username` VARCHAR(60) NOT NULL DEFAULT '' COMMENT '登录名',
`password` CHAR(32) NOT NULL DEFAULT '' COMMENT '登陆password',
PRIMARY KEY (`id`), -- 主键
INDEX (`username`) -- 索引
) ENGINE=INNODB DEFAULT CHARSET=utf8 COMMENT='新建表';
c>.改动表名
ALTER TABLE 表名1 RENAME TO 表名2;
d>.加入列
ALTER TABLE 表名 ADD COLUMN 列名 列类型(如:VARCHAR(30));
e>.删除列
ALTER TABLE 表名 DROP COLUMN 列名;
f>.几条简单的sql语句
选择:SELECT * FROM 表名 WHERE 范围;
插入:INSERT INTO 表名(字段名1,字段名2) VALUES(字段值1,字段值2);
删除:DELETE FROM 表名 WHERE 范围;
更新:UPDATE 表名 SET 字段名=字段值 WHERE 范围;
查找:SELECT * FROM 表名 WHERE 字段名 LIKE ’% 字段值 %’ ;
排序:SELECT * FROM 表名 ORDER BY 字段名1,字段名2 [DESC];
总数:SELECT COUNT AS totalcount FROM 表名;
求和:SELECT SUM(字段值) AS sumvalue FROM 表名;
平均:SELECT AVG(字段名) AS avgvalue FROM 表名;
最大:SELECT MAX(字段名) AS maxvalue FROM 表名;
最小:SELECT MIN(字段名) AS minvalue FROM 表名;
g>.赋予数据库用户权限(每一个数据库都创建单独的用户)
CREATE USER '项目用户'@'localhost' IDENTIFIED BY '项目用户password';
GRANT ALL PRIVILEGES ON 数据库名称.* TO 项目用户@'localhost' ;
或者
GRANT ALL PRIVILEGES ON 数据库名称.* TO username@'%' IDENTIFIED BY '用户password';(用’%'表示从不论什么地址连接)
h>.加入主键
ALTER TABLE 表名 ADD PRIMARY KEY(列名);
i>.创建索引
CREATE INDEX 字段名 ON 表名;
j>.删除索引
DROP INDEX 字段名;
k>.创建视图
CREATE VIEW 视图名 AS
SELECT 语句;
l>.删除视图
DROP VIEW 视图名;
m>.联合查询(这块有非常多内容。我这里仅仅提出主要的)
结果集列联合:JOIN ,这里我经常使用的是LEFT JOIN 。格式例如以下:
SELECT a.a, a.b, b.c, b.d FROM a LEFT OUT JOIN b ON a.a = b.c;
结果集行联合:UNION或者UNION ALL。格式例如以下(注意列的名称和个数一定要一致):
SELECT a.a as col1, a.b as col2 from a
UNION ALL
SELECT b.c as col1, b.d as col2 from b;
n>.分组:GROUP BY 一般与count,sum,max,min,avg联合使用
SELECT SUM(字段名1) FROM 表名 GROUP BY 字段名2;
o>.前10条记录
SELECT * FROM 表名 LIMIT 0,9;(mysql没有top语法。limit一般经常使用来分页)
p>.排序(desc降序;asc升序。默认是升序)
SELECT * FROM 表名 ORDER BY 列名 DESC;
二、进阶
a>.去重,一般经常使用 DISTINCT
SELECT DISTINCT * FROM 表名;
SELECT DISTINCT(列名) FROM 表名;
b>.复制表
CREATE TABLE 表名2 AS
(
SELECT * FROM 表名1
)
c>.查询分析器:在sql前面加上EXPLAIN或者DESC,查看该语句运行情况
EXPLAIN SELECT * FROM 表名;
三、贴一下做报表时写的一些恶心的sql
1.依据查询条件查询出符合条件的项目编号
SELECT DISTINCT(xp.Id)
FROM xmgl_finance_plan xfp LEFT JOIN xmgl_project xp ON xfp.proId = xp.Id WHERE 1=1
AND xp.proCategory IN ('ITER973')
AND xp.Id IN(0,1,2);
2.-- 查询项目计划表里相应的全部的预算科目相应的合计金额
SELECT
t.Pid,
xsb2.subjectName,
SUM(t.planTotalAmount) planTotalAmount,
SUM(t.planCurrentAmount) planCurrentAmount,
SUM(t.total_amount) total_amount,
SUM(t.payedMoney) payedMoney,
SUM(t.finalPayment) finalPayment,
SUM(t.CurYearPayedMoney) CurYearPayedMoney
FROM (SELECT
xsb.Id,
xsb.subjectName,
xsb.Pid,
SUM(xfp.planTotalAmount) planTotalAmount,
SUM(xfp.planCurrentAmount) planCurrentAmount,
SUM(xfp.total_amount) total_amount,
SUM(xfp.payedMoney) payedMoney,
SUM(xfp.finalPayment) finalPayment,
SUM(xfp.CurYearPayedMoney) CurYearPayedMoney
FROM xmgl_subject_budget xsb
LEFT JOIN xmgl_project xp
ON xsb.type = xp.subjectType
LEFT JOIN xmgl_finance_plan xfp
ON xsb.Id = xfp.subjectId
WHERE xp.Id = 1
GROUP BY xfp.subjectId,xsb.Id
ORDER BY xsb.Id) AS t
LEFT JOIN xmgl_subject_budget xsb2
ON t.Pid = xsb2.Id
WHERE t.Pid <> 0
GROUP BY t.Pid;
3.-- 查询各个部门在特定科目下的控制额度及支出信息(优化)
SELECT DISTINCT(xcs1.dept),xsc.subjectName,xcs2.amount,COALESCE(SUM(xfa.amount),0) payedMoney
,xcs2.amount-SUM(xfa.amount) leftAmount
FROM xmgl_control_subject xcs1
LEFT JOIN xmgl_control_subject xcs2 ON xcs1.dept = xcs2.dept AND xcs2.detailId = 3
LEFT JOIN xmgl_subject_control xsc ON xcs2.detailId = xsc.Id
LEFT JOIN xmgl_finance_activity xfa ON xcs2.dept = xfa.department AND xfa.detailId IN('22','23')
GROUP BY xcs1.dept,xcs1.detailId;
4.类似于QQ空间的消息列表
-- 赞了我
SELECT tf.id,1 AS typeId,c.avatar AS avatar, c.name,ct.catalog AS catalog, ct.id AS messageId, ct.content AS trendsContent,NULL AS replyContent, tf.create_time AS createTime,tf.read AS isRead
FROM trends_fork tf LEFT JOIN cust_trends ct ON tf.trends_id = ct.id LEFT JOIN customer c ON c.id = tf.customer_id
WHERE tf.master_id = 1
UNION ALL
-- 给我留言
SELECT cb.id,2 AS typeId,c.avatar AS avatar,c.name, 3 AS catalog,cb.id AS messageId,NULL AS trendsContent,cb.content AS replyContent,cb.create_time AS createTime,cb.read AS isRead
FROM cust_board cb LEFT JOIN customer c ON cb.customer_id = c.id WHERE cb.master_id = 1
UNION ALL
-- 评论我的动态
SELECT tr.id,3 AS typeId, c.avatar AS avatar, c.name, ct.catalog AS catalog, ct.id AS messageId, ct.content AS trendsContent, tr.content AS replyContent,tr.create_time AS createTime,tr.read AS isRead
FROM trends_reply tr LEFT JOIN cust_trends ct ON tr.trends_id = ct.id LEFT JOIN customer c ON c.id = tr.customer_id
WHERE tr.master_id = 1
UNION ALL
-- 回复了我评论的消息(包含直接回复我的评论、在我的动态下评论别人的回复)
SELECT tra.id,4 AS typeId,c.avatar AS avatar, c.name, ct.catalog AS catalog, tra.trends_id AS messageId,ct.content AS trendsContent, tra.content AS replyContent, tra.create_time AS createTime,tra.read AS isRead
FROM trends_replyat tra LEFT JOIN trends_reply tr ON tra.reply_id = tr.id LEFT JOIN customer c ON c.id = tra.customer_id LEFT JOIN cust_trends ct ON ct.id = tr.trends_id
WHERE tra.at = 1 OR (tra.master_id = 1 AND tra.customer_id != 1)
UNION ALL
-- 留言板中回复我的消息
SELECT cbr.id,5 AS typeId,c.avatar AS avatar, c.name, 3 AS catalog, cb.id AS messageId,cb.content AS trendsContent,cbr.content AS replyContent, cbr.create_time AS createTime,cbr.read AS isRead
FROM cust_board_reply cbr LEFT JOIN cust_board cb ON cbr.board_id = cb.id LEFT JOIN customer c ON cbr.customer_id = c.id
WHERE (cbr.board_customer_id = 1 AND cbr.customer_id != 1 ) OR (cbr.master_id = 1 AND cbr.customer_id != 1) ORDER BY createTime DESC
LIMIT 2,10
版权声明:本文博主原创文章,博客,未经同意,不得转载。
mysql声明摘要的更多相关文章
- Mysql 声明变量
Mysql 声明变量 Mysql中声明变量有两种方式 第一种: set @num=1; 或set @num:=1; //这里要使用变量来保存数据,直接使用@num变量 第二种: select @num ...
- SQLSERVER 脚本转MYSQL 脚本的方法总结
1.MYSQL(版本为5.6)中SQL脚本必须以分号(;)结尾,这点比SQLSERVER要严谨:关键字与函数名称全部大写:数据库名称.表名称.字段名称全部小写. 2.所有关键字都要加上``,比如 St ...
- oracle 、mysql、 sql server使用记录
oracle .mysql. sql server使用记录 mysql常用命令: mysqld --启动mysql数据库 show databases; -- 查看数据库 use database; ...
- win7下docker环境搭建nginx+php-fpm+easyswoole+lavarel+mysql开发环境
win7环境基础在上一篇win7下docker环境搭建nginx+php-fpm+easyswoole开发环境中已经详细叙述搭建完成 本篇文章将叙述如何在上述基础上搭建laravel开发环境,这个其实 ...
- Confluence 使用常见问题列表
Confluence 6 管理 Atlassian 提供的 App 摘要: Confluence 用户可以使用桌面应用来编辑一个已经上传到 Confluence 的文件,然后这个文件自动保存回 Con ...
- php namespace用法
其实纠结了很久要不要使用这个东西,但是看看了最新的框架laravel,cakephp等等的新版本都使用上了,所以还是随大流顺便学习下. namespace和c++里面的概念差不多,只是用法有点差别. ...
- SphinxSE的安装
SphinxSE 的使用 SphinxSE 的使用 :wiki SphinxSE是一个可以编译进MySQL 5.x版本的MySQL存储引擎,尽管被称作“存储引擎”,SphinxSE自身其实并不存储任何 ...
- Linux下javaweb
Linux下javaweb环境搭建 步骤: 1.使用远程工具连接上服务器,例如xsheel(ssh).filezilla(ftp) 2.JDK安装及相关配置 3.Mysql安装及相关配置 4.Tomc ...
- JQuery Smart UI
JQuery Smart UI 个人开发的一套使用htm+js的开发框架 SmartUI2.0后续声明 摘要: 感谢很多朋友关注,因为今年一直在另外一个公司做顾问,网络环境管制相当严格,所以一直没有更 ...
随机推荐
- ServicePrvider实现揭秘
ServicePrvider实现揭秘 到目前为止,我们定义的ServiceProvider已经实现了基本的服务提供和回收功能,但是依然漏掉了一些必需的细节特性.这些特性包括如何针对IServicePr ...
- [置顶] ※数据结构※→☆线性表结构(list)☆============双向链表结构(list double)(三)
双向链表也叫双链表,是链表的一种,它的每个数据结点中都有两个指针,分别指向直接后继和直接前驱.所以,从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和后继结点. ~~~~~~~~~~~~ ...
- WPF界面设计技巧(6)—玩玩数字墨水手绘涂鸦
原文:WPF界面设计技巧(6)-玩玩数字墨水手绘涂鸦 想让你的程序支持鼠标及手写笔涂鸦吗?只要敲入“<InkCanvas/>”这几个字符,你就会领悟什么叫“很好很强大”,今天我们来做一个手 ...
- A Game of Thrones(1) - Bran
The morning had dawned clear and cold, with a crispness(易碎:清新) that hinted(暗示:示意) at the end of summ ...
- Linux下hp打印机驱动hplip分析
Hplip分析 版本号是2.14,源代码位置:http://hplipopensource.com. 图的来源:http://hplipopensource.com/node/128. 实践中使用的打 ...
- Codeforces 191 C Fools and Roads (树链拆分)
主题链接~~> 做题情绪:做了HDU 5044后就感觉非常easy了. 解题思路: 先树链剖分一下,把树剖分成链,由于最后全是询问,so~能够线性操作.经过树链剖分后,就会形成很多链,可是每条边 ...
- Oracle ORA-01034,ORA-27101,ORA-00600
本机IP地址:192.168.1.163 [oracle@rtest ~]$ sqlplus /nolog SQL*Plus: Release 10.2.0.2.0 - Production on S ...
- C++0x新特性
我是在一个帖子上摘抄的大神语录...感谢supermegaboy大神,给了详尽的解释 下文是一篇转载的Wikipedia的译文,从语言和库双方面概述了C++0x. 右值引用与转移语义 在标准C++语言 ...
- nginx subrequest演示示例程序
只有简单subrequest应用演示示例. nginx.conf文件: #user nobody; worker_processes 1; #error_log logs/error.log; #er ...
- Spark 1.0.0 横空出世 Spark on Yarn 部署(Hadoop 2.4)
就在昨天,北京时间5月30日20点多.Spark 1.0.0最终公布了:Spark 1.0.0 released 依据官网描写叙述,Spark 1.0.0支持SQL编写:Spark SQL Progr ...