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 [email protected]'%' 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

版权声明:本文博主原创文章,博客,未经同意,不得转载。

时间: 2024-09-30 07:28:53

mysql声明摘要的相关文章

MySQL分区摘要

MySQL支持的分区类型为水平分区,并不支持垂直分区. 水平分区,以行为单位,划分到不同的物理文件中:垂直分区即针对列划分. MySQL的分区,除了InnoDB支持,MyISAM也支持,所以分区并不是引擎级别的事儿. 分区并不一定会让访问变得更快,尤其是OLTP应用,OLAP应用使用分区的效果往往更好. MySQL支持的如下几种分区类型. RANGE 行数据基于一个给定连续区间的列值划分. LIST 和RANGE类似,只是LIST面向的不是连续区间值,而是离散的集合. HASH 根据自定义的表达

mysql性能

监控MySQL的性能指标系列 / 数据库 / 度量 / mysql的 / 性能 这个职位是一个3部分组成的系列关于MySQL的第1部分监控. 第二 ??部分是关于从MySQL收集度量和第3部分解释了如何使用MySQL的Datadog进行监控. 什么是MySQL? MySQL的是世界上最流行 ??的开源关系数据库服务器. 属于Oracle,MySQL是在免费下载的社区版,以及在商业版本添加了功能和支持可用. 最初于1995年发布,MySQL已经催生以来高调叉子竞争性技术,如MariaDB的和Per

boost.sha1

#include <boost/uuid/sha1.hpp> #include <iostream> /* @brief SHA1摘要算法:一种很重要的密码学算法,可将任意长度的文本压缩成20个字节的 独一无二的的摘要(uuid名字生成器使用该算法) */ using namespace boost::uuids::detail; using namespace std; int main() { sha1 sha; // 声明摘要对象 char* szMsg = "Th

php namespace用法

其实纠结了很久要不要使用这个东西,但是看看了最新的框架laravel,cakephp等等的新版本都使用上了,所以还是随大流顺便学习下. namespace和c++里面的概念差不多,只是用法有点差别. 首先,如果我在index.php文件中想使用db/mysql.php这个文件里的mysql这个类. 使用方法如下: mysql.php文件: namespace DB; class Mysql { public function index(){ echo 'im mysql'; } } index

12mybatis调用执行存储过程

mybatis 调用执行存储过程 mysql 声明建立存储过程 删除 在mysql中调用 -- 声明定义存储过程 delimiter $$ create procedure delbook(id int) begin delete from book where book_id=id; end$$ delimiter ; -- 删除存储过程 drop procedure delbook; -- 调用执行存储过程 call delbook(4); select * from book; mybat

EasyTalking微博系统

摘要 随着互联网的迅猛发展,人们的日常生活.学习工作已经离不开网络.人们的生活和工作在未来的生活中将越来越依赖于计算机网络技术的发展,越来越网络化.电子化.虚拟化.便捷化.Internet目前的应用历程和发展趋势,可以相信网络科学技术将极大的改变人们的日常生活和工作方式,甚至是社会的价值观. 本设计尝试用JSP在网络上架构一个EasyTalking微博,以推进微博电子化,管理智能化的发展.本文从理论和实践两个角度出发,对一个具有数据分析功能的EasyTalking微博进行设计与实现分析.论文首先

排序学习简介

译排序学习简介 声明 摘要 排序问题Training and Testing 1 训练和测试Training and Testing 2 数据标记Data Labeling 3 度量Evaluation 4 与传统分类问题的关系Relation with Ordinal Classification 公式 点对方法Pointwise Approach 1 SVM在顺序分类问题中的使用 序列方法Pairwise Approach 1 Ranking SVM 2 IR SVM Listwise Ap

使用回调函数处理数组的函数

函数的回调是PHP中的一种特殊机制,这种机制允许在函数的参数列表中,传入用户自定义的函数地址作为参数处理或完成一定的操作.使用回调函数可以很容易地显示一些所需的功能.以下将介绍主要的几个使用回调函数处理数组的函数. ①函数array_filter()array_filter函数用回调函数过滤数组中的元素,返回按用户自定义函数过滤后的新数组.该函数有两个参数,其函数的原型如下: array array_filter(array input [,callback callback]) 该函数的第一个

C# 事件详解

1.事件的本质是什么 答:事件是委托的包装器,就像属性是字段的包装器一样 2.为什么有了委托还有有事件 委托可以被访问就可以被执行,事件则只能在类的内部执行 3.事件要怎么声明 a.明一个委托 //委托用于事件,约定以EventHandle结束 ,参数一般要有一个事件拥有者,和一个事件参数 ,这三者是同级的关系,所以三个类访问级别要一致//为什么说三者呢,因为委托虽然写法比较怪,但也是一个类 public delegate void DelegateNameEventHandle(IHaveEv