一 . 基本命令:
//启动mysql服务器 net start mysql //关闭 net stop mysql //进入 mysql -h 主机地址 -u 用户名 -p 用户密码 //退出 exit #--------------------------- #----MySql用户管理--------- //修改密码:首先在DOS 下进入mysql安装路径的bin目录下,然后键入以下命令: mysqladmin -uroot -p123 password 456; //增加用户 //格式:grant 权限 on 数据库.* to 用户名@登录主机 identified by '密码' /* 如,增加一个用户user1密码为password1,让其可以在本机上登录, 并对所有数据库有查询、插入、修改、删除的权限。 首先用以root用户连入mysql,然后键入以下命令: grant select,insert,update,delete on *.* to user1@localhost Identified by "password1"; 如果希望该用户能够在任何机器上登陆mysql,则将localhost改为"%"。 如果你不想user1有密码,可以再打一个命令将密码去掉。 grant select,insert,update,delete on mydb.* to user1@localhost identified by ""; */ grant all privileges on wpj1105.* to sunxiao@localhost identified by '123'; #all privileges 所有权限
二. 单表操作
#显示数据库
show databases;
#判断是否存在数据库schools,有的话先删除
drop database if exists schools;
/*创建指定名称的数据库*/ CREATE DATABASE schools;
/*使用哪一个数据库*/ use `爱仕达多`;
/*显示某个数据库下的所有数据表*/ show TABLES;
/*删除数据库*/ DROP DATABASE schools;
/*查看表结构*/ desc student;
/*删除表*/ drop TABLE tb_admin1;
/*创建表*/ CREATE TABLE tb_admin1( `admin_id` int(10), `admin_name` VARCHAR(20), `admin_pass` VARCHAR(20) ); CREATE TABLE `order`( `admin_id` int(10), `admin_name` VARCHAR(20), `admin_pass` VARCHAR(20) ); /*修改表结构*//*通过表的字段名修改字段属性(类型、长度、约束、默认值)*/ ALTER TABLE `tb_admin` MODIFY `admin_name` CHAR(5) not null ; /*查看表结构*/ desc `tb_admin`; /*查看表结构2*/ /*将查看的表以DDL方式显示*/ SHOW create TABLE tb_admin; /*删除表*/ /*会删除表内的数据和表结构*/ drop table tb_admin;
三. 单表查询
/*创建product表*/ DROP TABLE IF EXISTS `product`; CREATE TABLE `product` ( `id` bigint(11) NOT NULL auto_increment, `productName` varchar(50) default NULL, `dir_id` bigint(11) default NULL, `salePrice` double(10,2) default NULL, `supplier` varchar(50) default NULL, `brand` varchar(50) default NULL, `cutoff` double(2,2) default NULL, `costPrice` double(10,2) default NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8; /*id 唯一标识主建 productName 产品名称 dir_id 分类编码 salePrice 零售价 supplier 供应商 brand 品牌 cutoff 折扣 costPrice 成本价 */ INSERT INTO `product` VALUES ('1', '罗技M90', '3', '90.00', '罗技', '罗技', '0.50', '35.00'); INSERT INTO `product` VALUES ('2', '罗技M100', '3', '49.00', '罗技', '罗技', '0.90', '33.00'); INSERT INTO `product` VALUES ('3', '罗技M115', '3', '99.00', '罗技', '罗技', '0.60', '38.00'); INSERT INTO `product` VALUES ('4', '罗技M125', '3', '80.00', '罗技', '罗技', '0.90', '39.00'); INSERT INTO `product` VALUES ('5', '罗技木星轨迹球', '3', '182.00', '罗技', '罗技', '0.80', '80.00'); INSERT INTO `product` VALUES ('6', '罗技火星轨迹球', '3', '349.00', '罗技', '罗技', '0.87', '290.00'); INSERT INTO `product` VALUES ('7', '罗技G9X', '3', '680.00', '罗技', '罗技', '0.70', '470.00'); INSERT INTO `product` VALUES ('8', '罗技M215', '2', '89.00', '罗技', '罗技', '0.79', '30.00'); INSERT INTO `product` VALUES ('9', '罗技M305', '2', '119.00', '罗技', '罗技', '0.82', '48.00'); INSERT INTO `product` VALUES ('10', '罗技M310', '2', '135.00', '罗技', '罗技', '0.92', '69.80'); INSERT INTO `product` VALUES ('11', '罗技M505', '2', '148.00', '罗技', '罗技', '0.92', '72.00'); INSERT INTO `product` VALUES ('12', '罗技M555', '2', '275.00', '罗技', '罗技', '0.88', '140.00'); INSERT INTO `product` VALUES ('13', '罗技M905', '2', '458.00', '罗技', '罗技', '0.88', '270.00'); INSERT INTO `product` VALUES ('14', '罗技MX1100', '2', '550.00', '罗技', '罗技','0.76', '300.00'); INSERT INTO `product` VALUES ('15', '罗技M950', '2', '678.00', '罗技', '罗技', '0.78', '320.00'); INSERT INTO `product` VALUES ('16', '罗技MX Air', '2', '1299.00', '罗技', '罗技', '0.72', '400.00'); INSERT INTO `product` VALUES ('17', '罗技G1', '4', '155.00', '罗技', '罗技', '0.80', '49.00'); INSERT INTO `product` VALUES ('18', '罗技G3', '4', '229.00', '罗技', '罗技', '0.77', '96.00'); INSERT INTO `product` VALUES ('19', '罗技G500', '4', '399.00', '罗技', '罗技', '0.88', '130.00'); INSERT INTO `product` VALUES ('20', '罗技G700', '4', '699.00', '罗技', '罗技', '0.79', '278.00'); -- 查询所有货品信息 SELECT * FROM product; -- 查询所有货品的id,productName,salePrice SELECT id,productName,salePrice FROM product; -- 查询商品的分类编号 ( 避免重复数据-DISTINCT ) SELECT DISTINCT dir_id FROM product; -- 查询所有货品的id,名称和批发价(批发价=卖价*折扣) SELECT id,productName,salePrice*cutoff FROM product; -- 查询所有货品的id,名称,和各进50个的成本价(成本=costPrice) SELECT id,productName,costPrice*50 FROM product; -- 查询所有货品的id,名称,各进50个,并且每个运费1元的成本 SELECT id,productName,(costprice+1)*50 FROM product; -- 查询所有货品的id,名称,各进50个,并且每个运费1元的成本(使用别名) SELECT id 编号,productName 产品名称,(costprice+1)*50 总的费用 FROM product; -- 需求:查询商品的名字和零售价(salePrice)。(CONCAT) -- 格式:xxx商品的零售价为:xxx SELECT CONCAT(productName,'商品的零售价为:',salePrice) AS productSalePrice FROM product; -- 过滤器查询 -- 查询货品名 不为 罗技G9X的所有货品信息. SELECT * FROM product WHERE productName <> "罗技G9X"; -- 查询分类编号不等于2的货品信息 SELECT * FROM product WHERE dir_id <> 2; -- 查询id,货品名称,批发价(salePrice*cutoff)大于350的货品 SELECT id 编号,productName 产品名称,(salePrice*cutoff)批发价 FROM product WHERE salePrice*cutoff>350; -- 选择id,货品名称,批发价(saleprice*cutoff)在300-400之间的货品 -- 选择id,货品名称,批发价不在300-400之间的货品 SELECT id 编号,productName 产品名称,(salePrice*cutoff)批发价 FROM product WHERE (saleprice*cutoff) BETWEEN 300 AND 400; SELECT id 编号,productName 产品名称,(salePrice*cutoff)批发价 FROM product WHERE (saleprice*cutoff) not BETWEEN 300 AND 400; -- 选择id,货品名称,分类编号为2,4的所有货品 -- 选择id,货品名称,分类编号不为2,4的所有货品 SELECT id,productName,dir_id FROM product WHERE dir_id IN (2,4); SELECT id,productName,dir_id FROM product WHERE dir_id not IN (2,4); -- 选择id,货品名称,分类编号的货品零售价(saleprice)大于等于250或者是成本(costprice)大于等于200 SELECT id,productName,dir_id FROM product WHERE saleprice>=250 || costprice>=200 ; -- 查询商品名为NULL的所有商品 -- 查询商品名不为NULL的所有商品 select * from product where productName is null; select * from product where productName is not null; -- 模糊查询-LIKE %通配符:可表示零或多个字符。 _通配符:可表示一个字符。 -- 查询id,货品名称,货品名称匹配'%罗技M9_' SELECT id,productName FROM product WHERE productName LIKE "%罗技M9_"; -- 查询id,货品名称,分类编号,零售价大于等于200并且货品名称匹配'%罗技M1__ SELECT id,productName dir_id FROM product WHERE salePrice>=200 AND productName LIKE "%罗技M1__"; -- 结果排序 ORDER BY -- 查询M系列并按照批发价(salePrice*cutoff)排序(加上别名 注意:不能使用中文的别名排序。) SELECT productName,(salePrice*cutoff) pfj FROM product WHERE productName LIKE '%M%' ORDER BY pfj; -- 查询分类为2并按照批发价排序(加上别名) SELECT productName,dir_id,(salePrice*cutoff) pfj FROM product WHERE dir_id=2 ORDER BY pfj; -- 分页查询 LIMIT beginIndex,pageSize; /*beginIndex:是开始索引(从0开始):第一条记录:0,第二条记录:1 pageSize:每页显示多少条数据 beginIndex = (当前页数 - 1) * pageSize*/ -- 每页最多3条记录: pageSize = 3: SELECT * FROM product LIMIT 0,3; SELECT * FROM product LIMIT 3,3; SELECT * FROM product LIMIT 6,3; SELECT * FROM product LIMIT 9,3; -- 每页6条数据,要查询前3页 SELECT * FROM product LIMIT 0,6; SELECT * FROM product LIMIT 6,6; SELECT * FROM product LIMIT 12,6; -- 聚集函数 使用聚集函数的时候,不要添加列名 -- 查询所有商品平均零售价 SELECT AVG(saleprice) FROM product; -- 查询商品总记录数(注意在Java中必须使用long接收 SELECT COUNT(*) FROM product; -- 查询分类为2的商品总数 SELECT COUNT(*) FROM product WHERE dir_id=2; -- 查询商品的最小零售价,最高零售价,以及所有商品零售价总和 SELECT MIN(saleprice),MAX(saleprice),SUM(saleprice) FROM product; -- 分组查询 -- Group by HAVING对分组之后的结果作筛选.不能在 WHERE 子句中使用组函数(注意)。可以在 HAVING 子句中使用组函数。 -- 查询每个商品分类编号和每个商品分类各自的平均零售价(求2,3,4每类商品的平均零售价) select avg(saleprice),dir_id from product group by dir_id; -- 查询每个商品分类编号和每个商品分类各自的商品总数。(求2,3,4每类商品的总数) SELECT dir_id,COUNT(*) FROM product GROUP BY dir_id; -- 查询每个商品分类编号和每个商品分类中零售价大于100的商品总数: SELECT dir_id, COUNT(*) FROM product WHERE salePrice>100 GROUP BY dir_id; -- 查询 零售价总和大于1500的 商品分类编号以及总零售价和;(根据分类编号查零售价的总和,然后零售价总和大于1500) SELECT dir_id, SUM(salePrice) SumSalePrice FROM product GROUP BY dir_id HAVING SumSalePrice>1500;