一、SQL基础和DDL、DML语句

MYSQL数据库软件

数据库登陆

# 本地登陆
mysql -uroot -p密码
# 远程登陆,两种
mysql -hip -Pport -uroot -p密码
mysql --h=ip --P=port --u=root --p=密码

数据库目录结构(mac上的稍后处理)

  • mysql安装目录
  • mysql数据目录

SQL的概念

什么是sql?

Structured Query Language :结构化查询语言

其实就是定义了所有操作关系型数据库的规则

SQL通用语法

  1. SQL语句可以单行或多行书写, 以分号结尾;
  2. 可以使用空格和缩进增加可读性;
  3. MYSQL数据库的SQL语句不区分大小写,但关键字建议用大写;
  4. 注释:

单行注释使用 – 注释内容 或 # 注释内容(后者为MYSQL特有)

多行注释使用 /* */

SQL分类

  • DDL(操作数据库和表)
  • DML(增删改表中的记录)
  • DQL(查询表中的记录)
  • DCL(授权处理)

DDL:操作数据库、表

一、操作数据库:CRUD

1、C(create):创建
    * 创建数据库
        create database 数据库名称;
    *  创建数据库,判断是否存在
        create database if not exists 数据库名称;
    * 创建数据库,并指定字符集
        create database 数据库名称 chatacter set gk;
    * 创建一个db4的数据库,判断是否存在,并指定字符集为gbk
        create database if not exists db4 character set gbk;
2、R(retrieve):
    * 查询所有数据库的名称
        show databases;
    * 查询某个数据库的字符集:查询某个数据库的创建语句
        show create database 数据库名称;
3、U(update):修改
 	* 修改数据库的字符集
 		*  alter database 数据库名称 character set 字符集名称;
4、D (delete):删除
	* 删除数据库
			* drop database 数据库名称;
	* 删除数据库,如果数据库存在
			* drop database if exists 数据库名称;
5、使用数据库
		* 查询当前正在使用的数据库名称
			* select database(); 
		*	使用数据库
			* use 数据库名称;

二、操作表

1、C(create):创建
    * 创建数据库
        create table 表名(
        	列名1 数据类型1,
        	列名2 数据类型2,
        	列名3 数据类型3,
        	列名4 数据类型4
        	);
        * 注意:最后一列,不需要加逗号(,)
        * 数据类型:
        		1、int:整数类型
        			* age int,
        		2、double:小数类型
        			* score double(5,2)
        		3、date:日期,只包含年月日,yyyy-MM-dd
        		4、datetime:日期,包含年月日时分秒,yy-MM-dd HH:mm:ss
        		5、timestamp:时间戳类型,包含年月日时分秒,yy-MM-dd HH:mm:ss
        				*  如果不给这个字段赋值或者赋值为 null,则默认使用当前的系统时间,来自动赋值
        		6、varchar:字符串类型
        				* name varchar(20):表示姓名最大长度为20个字符
        				* zhangsan 8个字符 张三 2个字符
        * 创建一张学生表
        	create table student(
        		id int,
        		name varchar(32),
        		age int,
        		score double(4,1),
        		birthday date,
        		insert_time timestamp 
        	);
    *  创建表,判断是否存在
        create table if not exists 表名称;
	*  复制一个表
			create table  表名 like 原始表;
2、R(retrieve):
    * 查询某个数据库中所有表的名称
        show tables;
    * 查询表结构
    		desc 表名;
3、U(update):修改
 	* 修改表的名称
 		 alter table 表名 rename to 新表名;
 	* 修改表的字符集
 		alter table 表名  character set 字符集名称;
 	* 添加列
 			alter table 表名 add 列名 数据类型 ;
 	* 修改列名 数据类型
 			 alter table 表名 change 原列名 新列名 新数据类型;
 			 alter table 表名 modify 原列名 新数据类型;
 	* 删除列
 			alter table 表名 drop 列名;
4、D (delete):删除
	* 删除表
			* drop table 表名称;
	* 删除表,如果表存在
			* drop table if exists 表名称;

DML

1. 添加数据
	* 语法
		* insert into 表名(列名1,列名2,... ,列名n ) values (值1, 值2,... , 值n);
	* 注意:
			- 列名和值要一一对应
			- 如果表名后,不定义列名,则默认给所有列添加值
			- 除了数字类型,其他类型需要使用引号引起来(单双引号都可以)
			
2. 删除数据
		* 语法:
			* delete from 表名 where 条件;
		* 注意:
			- 如果不加条件,则会删除表中的所有记录;
			- 如果要删除表中所有数据:
					* truncate table 表名; -- 删除表,然后再创建一个相同的空表
					* delete  from 表名; -- 不建议使用,有多少数据就执行多少次
					
3. 修改数据
	* 语法:
		* update 表名 set 列名1=值1,列名2=值2,... [where 条件 ];
	* 注意:
	 	1、如果不加任何条件,会将表中的数据全部修改掉。
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值