基本的sql 语句

1,登陆数据库:mysql -u root -p2,退出数据库:exit quit ctr+d3,创建数据库:create database 数据库名 charset=utf84,使用数据库:use 数据库名5,删除数据库:drop database 数据库名

6,创建表:create table 表名(字段名,字段类型,约束条件)7,添加字段:alter table 表名 add 字段名 字段类型 约束条件8,修改字段类型:alter table 表名 modify 字段名 字段类型 约束条件9,修改字段名和字段类型:alter table 表明 change 原字段名 新字段名 字段类型 约束条件10,删除字段:alter table 表名 drop 字段名11,删除表:drop table 表名12,查询数据:select * from 表名;13,插入数据:insert into 表名 values(...)    或:insert into 表名(列名1,列名2) values(1,2),(1,3);14,修改数据:update 表名 set 列1=值1,列2=值2...where 条件15,删除数据:delete from 表名 where 条件

准备数据库
-- 创建 "京东" 数据库
create database jing_dong charset=utf8;

-- 使用 "京东" 数据库
use jing_dong;

-- 创建一个商品goods数据表

create table goods(
    id int unsigned primary key auto_increment not null,
    name varchar(150) not null,
    cate_name varchar(40) not null,
    brand_name varchar(40) not null,
    price decimal(10,3) not null default 0,
    is_show bit not null default 1,
    is_saleoff bit not null default 0
);



-- 向goods表中插入数据

insert into goods values(0,‘r510vc 15.6英寸笔记本‘,‘笔记本‘,‘华硕‘,‘3399‘,default,default);
insert into goods values(0,‘y400n 14.0英寸笔记本电脑‘,‘笔记本‘,‘联想‘,‘4999‘,default,default);
insert into goods values(0,‘g150th 15.6英寸游戏本‘,‘游戏本‘,‘雷神‘,‘8499‘,default,default);
insert into goods values(0,‘x550cc 15.6英寸笔记本‘,‘笔记本‘,‘华硕‘,‘2799‘,default,default);
insert into goods values(0,‘x240 超极本‘,‘超级本‘,‘联想‘,‘4880‘,default,default);
insert into goods values(0,‘u330p 13.3英寸超极本‘,‘超级本‘,‘联想‘,‘4299‘,default,default);
insert into goods values(0,‘svp13226scb 触控超极本‘,‘超级本‘,‘索尼‘,‘7999‘,default,default);
insert into goods values(0,‘ipad mini 7.9英寸平板电脑‘,‘平板电脑‘,‘苹果‘,‘1998‘,default,default);
insert into goods values(0,‘ipad air 9.7英寸平板电脑‘,‘平板电脑‘,‘苹果‘,‘3388‘,default,default);
insert into goods values(0,‘ipad mini 配备 retina 显示屏‘,‘平板电脑‘,‘苹果‘,‘2788‘,default,default);
insert into goods values(0,‘ideacentre c340 20英寸一体电脑 ‘,‘台式机‘,‘联想‘,‘3499‘,default,default);
insert into goods values(0,‘vostro 3800-r1206 台式电脑‘,‘台式机‘,‘戴尔‘,‘2899‘,default,default);
insert into goods values(0,‘imac me086ch/a 21.5英寸一体电脑‘,‘台式机‘,‘苹果‘,‘9188‘,default,default);
insert into goods values(0,‘at7-7414lp 台式电脑 linux )‘,‘台式机‘,‘宏碁‘,‘3699‘,default,default);
insert into goods values(0,‘z220sff f4f06pa工作站‘,‘服务器/工作站‘,‘惠普‘,‘4288‘,default,default);
insert into goods values(0,‘poweredge ii服务器‘,‘服务器/工作站‘,‘戴尔‘,‘5388‘,default,default);
insert into goods values(0,‘mac pro专业级台式电脑‘,‘服务器/工作站‘,‘苹果‘,‘28888‘,default,default);
insert into goods values(0,‘hmz-t3w 头戴显示设备‘,‘笔记本配件‘,‘索尼‘,‘6999‘,default,default);
insert into goods values(0,‘商务双肩背包‘,‘笔记本配件‘,‘索尼‘,‘99‘,default,default);
insert into goods values(0,‘x3250 m4机架式服务器‘,‘服务器/工作站‘,‘ibm‘,‘6888‘,default,default);
insert into goods values(0,‘商务双肩背包‘,‘笔记本配件‘,‘索尼‘,‘99‘,default,default);



-- sql强化演练( goods 表练习)

-- 查询类型 cate_name 为 ‘超级本‘ 的商品名称 name 、价格 price

select name,price from goods where cate_name = ‘超级本‘;

-- 显示商品的种类
-- 1 分组的方式( group by )

select cate_name from goods group by cate_name;

-- 2 去重的方法( distinct )

select distinct cate_name from goods;

-- 求所有电脑产品的平均价格 avg ,并且保留两位小数( round )

select round(avg(price),2) from goods;

-- 显示 每种类型 cate_name (由此可知需要分组)的 平均价格

select cate_name,avg(price) from goods group by cate_name;

-- 查询 每种类型 的商品中 最贵 max 、最便宜 min 、平均价 avg 、数量 count

select cate_name,max(price),min(price),avg(price),count(*) from goods group by cate_name;

-- 查询所有价格大于 平均价格 的商品,并且按 价格降序 排序 order desc
--1.平均价格
select avg(price) from goods;

--2.大于平均价格

select * from goods where price > 5570.571428;

select * from goods where price > (select avg(price) from goods) order by price desc;

-- 查询每种类型中最贵的电脑信息(难)

-- 1 查找 每种类型 中 最贵的 max_price 价格

select cate_name,max(price) from goods group by cate_name;

select * from goods where (cate_name,price) = (‘台式机‘,9188);

-- 2 查询最贵的信息

select * from goods where (cate_name,price) in (select cate_name,max(price) from goods group by cate_name);

--第四部 修改表结构(重点是思路)

-- 创建表格的格式
--create table if not exists 表名 (
--id int unsigned primary key auto_increment, 这个是主键
--name varchar(40) not null); 这个名称

--第一步 创建 "商品种类表" -goods_cates
--id跟名称

create table goods_cates(id int unsigned primary key auto_increment,name varchar(100));

select cate_name from goods group by cate_name;

insert into goods_cates(name) (select cate_name from goods group by cate_name);

--第二步 创建 "商品品牌表" -goods_brands
--id跟名称

create table goods_brands (id int unsigned primary key auto_increment,name varchar(100));

--第三步 更新种类信息表
--1. 要把类型查询出来

--2. 批量插入数据
--insert into goods_cates (name) values(‘123‘);

# 批量插入的语句

--第四 更新品牌信息表
--1. 要把品牌信息查询出来

select brand_name from goods group by brand_name;

--2. 批量插入数据

insert into goods_brands(name) (select brand_name from goods group by brand_name);

--第五 更新种类信息成种类信息表中的id
--1. 种类信息跟要替换成表进行内联

select * from goods inner join goods_cates on goods.cate_name = goods_cates.name;

--2. 通过特殊的update 进行更新
# 注意两张表连接的时候 select * from 这个必须删除

update (goods inner join goods_cates on goods.cate_name = goods_cates.name)
set goods.cate_name = goods_cates.id;

--第六 更新品牌信息成品牌信息表的id
--1. 把要更新的表两张表进行内联

select * from goods inner join goods_brands on goods.brand_name = goods_brands.name ;

--2.通过特殊的update语句进行更新

update (goods inner join goods_brands on goods.brand_name = goods_brands.name)
set goods.brand_name = goods_brands.id;

--第七步 修改字段(注意类型必须跟外键的主键类型一致)
-- alter table 表名 change 旧字段 新字段 类型
alter table goods change brand_name brand_id int unsigned;
alter table goods change cate_name cate_id int unsigned;

-- 外键的使用(了解)

-- 向goods表里插入任意一条品牌数据"老王牌拖拉机"
-- 你会发现我们外键不能创建,因为没有对应的品牌

-- 约束 数据的插入 使用 外键 foreign key
-- alter table 主表名 add foreign key (主表的外键) references 外键表(外键主键);

alter table goods add foreign key (cate_id) references goods_cates(id);

-- 创建表的同时设置外键 (注意 goods_cates 和 goods_brands 两个表必须事先存在)
-- foreign key (主表的外键) references 外键表(主键)
create table if not exists goods_key(
id int primary key auto_increment not null,
name varchar(40) default ‘‘,
price decimal(5,2),
cate_id int unsigned,
brand_id int unsigned,
is_show bit default 1,
is_saleoff bit default 0,
-- 添加外键
foreign key (cate_id) references goods_brands(id)

);

-- 如何取消外键约束
-- 需要先获取外键约束名称,该名称系统会自动生成,可以通过查看表创建语句来获取名称
--show create table 表名;

show create table goods;

-- 获取名称之后就可以根据名称来删除外键约束
--alter table 表名 drop foreign key 外键名;

alter table goods drop foreign key goods_ibfk_1;

alter table goods drop key cate_id;

原文地址:https://www.cnblogs.com/wjun0/p/11515435.html

时间: 2024-10-29 00:30:28

基本的sql 语句的相关文章

oracle sql语句运行效率

--当前执行sql语句 SELECT a.SID , a.SERIAL# , a.USERNAME , b.PARSE_CALLS , b.PARSING_SCHEMA_NAME , b.CPU_TIME / 1000000 , b.ELAPSED_TIME / 1000000 , b.DISK_READS , b.DIRECT_WRITES , b.BUFFER_GETS , a.event , b.sql_text , b.SQL_FULLTEXTFROM v$session a INNER

sql 语句之 case

case语句语法: --简单Case函数 CASE sex WHEN '1' THEN '男' WHEN '2' THEN '女' ELSE '其他' END --Case搜索函数 CASE WHEN sex = '1' THEN '男' WHEN sex = '2' THEN '女' ELSE '其他' END 首先创建一张users表,其中包含id,name,sex三个字段,表内容如下: 复制代码 SQL> drop table users purge; drop table users p

用sql语句导出oracle中的存储过程和函数

用sql语句导出oracle中的存储过程和函数: SET echo off ; SET heading off ; SET feedback off ; SPOOL 'C:/PRC.SQL' replace SELECT CASE WHEN LINE = 1 THEN 'CREATE OR REPLACE ' || TEXT WHEN LINE = MAX_LINE THEN TEXT || CHR(10 ) || '/' ELSE TEXT END FROM USER_SOURCE A LEF

JDBC系列:(3)使用PreparedStatement执行sql语句

执行sql语句的接口 接口 作用 Statement接口 用于执行静态的sql语句 PreparedStatement接口 用于执行预编译sql语句 CallableStatement接口 用于执行存储过程的sql语句(call xxx) PreparedStatement Vs Statement 序号 不同 描述 1 语法不同 PreparedStatement可以使用预编译的sql,而Statment只能使用静态的sql 2 效率不同 PreparedStatement可以使用sql缓存区

【黑马Android】(04)数据库的创建和sql语句增删改查/LinearLayout展示列表数据/ListView的使用和BaseAdater/内容提供者创建

数据库的创建和sql语句增删改查 1. 加载驱动. 2. 连接数据库. 3. 操作数据库. 创建表: create table person( _id integer primary key, name varchar(20), age integer ); 添加: insert into person(name, age) values('lisi', 19); 删除: delete from person where _id = 1; 修改: update person set name =

应用系统如何分析和获取SQL语句的执行代码

大部分开发人员都有这样一个需求,在程序连接数据库执行时,有时需要获取具体的执行语句,以便进行相关分析,这次我向大家介绍一下通用权限管理系统提供的SQL语句执行跟踪记录,直接先看看代码吧:(这个功能我也是在看底层代码时发现的) namespace DotNet.Utilities { /// <summary> /// SQLTrace /// 记录SQL执行 Global 中设置 BaseSystemInfo.LogSQL=true 可以开启跟踪记录 /// /// /// 修改纪录 ///

SQL 语句日期用法及函数

SQL 语句日期用法及函数 --DAY().MONTH().YEAR()——返回指定日期的天数.月数.年数:select day(cl_s_time) as '日' from class  --返回天select '月'=month(cl_s_time) from class  --返回月select '年'=year(cl_s_time) from class  --返回年 --DATEADD(datepart,number,date)——在日期上增加给定日期类型的数量:select date

标准sql语句,学习

标准SQL语句总结标准SQL语句总结,标准SQL语言基本上适用于下面所列出的数据库软件 ----------------------------------------------------------------------------- 数据库软件清单 A商业数据库软件如下 1.微软的MS SQL Server和Access 2.IBM的DB2,informax 3.Sybase的大型数据库ASE,中小型数据库ASA 4.甲骨文公司的Oracle8.0,oracle9i系列 5.Borla

实用SQL语句

一.基础 1.说明:创建数据库 CREATE DATABASE database-name 2.说明:删除数据库 drop database dbname 3.说明:备份sql server --- 创建 备份数据的 device USE master EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat' --- 开始 备份 BACKUP DATABASE pubs TO testBack 4.说明:创建

oracle sql语句取得本周本月本年的数据

[sql] --国内从周一到周日 国外是周日到周六  select to_char(sysdate-1,'D') from dual;--取国内的星期几 去掉减一取国外的星期-- [sql] --取本周时间内的数据  select * from table  where DTIME >=trunc(next_day(sysdate-8,1)+1) and DTIME<=trunc(next_day(sysdate-8,1)+7)+1 ;     select * from table  whe