DDl,DML语句

DDl,DML语句1 数据库 1 概述数据库 DataBase DB 指长期保存在计算机的存储设备上 按照一定规则组织起来 可以被各种用户或应用共享的数据集合 数据库管理系统 DataBaseMana DBMS 指一种操作和管理数据库的大型软件 用于建立 使用和维护数据库 对数据库进行统一管理和控制 以保证数据库的安全性和完整性 用户通过数据库管理系统访问数据库中的数据 数

1.数据库

1.概述

在这里插入图片描述

  1. 数据库(DataBase,DB):指长期保存在计算机的存储设备上,按照一定规则组织起来,可以被各种用户或应用共享的数据集合。
  2. 数据库管理系统(DataBase Management System,DBMS):指一种操作和管理数据库的大型软件,用于建立、使用和维护数据库,对数据库进行统一管理和控制,以保证数据库的安全性和完整性。用户通过数据库管理系统访问数据库中的数据。
  3. 数据库软件应该为数据库管理系统,数据库是通过数据库管理系统创建和操作的。
  4. 数据库:存储、维护和管理数据的集合。

2.分类

1.关系型数据库(sql)

Oracle:是Oracle公司的数据库产品

Mysql: 最早属于瑞典的MysqlAB公司的,后被Sun公司收购,Sun在2009年4月20号被Oracle收购。

SQLServer:微软旗下的数据库产品

Access:微软旗下的数据库产品

DB2:IBM公司旗下的数据库产品

2.非关系型数据库(nosql)

HBase是一个分布式的、面向列的开源数据库

MongoDB是一个基于分布式文件存储的数据库

Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API

2.SQL

1.分类

  1. DDL:数据定义语言,用来定义数据库对象:库、表、列等;
  2. DML:数据操作语言,用来定义数据库记录(数据);
  3. DCL:数据控制语言,用来定义访问权限和安全级别;
  4. DQL:数据查询语言,用来查询记录(数据)。

2.DDL

1.关键字

使用的关键字:CREATE、 ALTER、DROP

2.操作数据库
//创建 Create database mydb1; Create database mydb2 character set gbk; Create database mydb3 character set gbk COLLATE gbk_chinese_ci; //查询 //查看当前数据库服务器中的所有数据库 Show databases; //查看前面创建的mydb2数据库的定义信息 Show create database mydb2; //删除前面创建的mydb3数据库 Drop database mydb3; // 修改 //查看服务器中的数据库,并把mydb2的字符集修改为utf8; alter database mydb2 character set utf8; //删除  //Drop database mydb3;  //查看当前使用的数据库 Select database(); //切换数据库 Use mydb2; 
3.操作表

语法:

create table 表名(

字段1 字段类型,

字段2 字段类型,

字段n 字段类型

);

常用数据类型:

int:整型

double:浮点型,例如double(5,2)表示最多5位,其中必须有2位小数,即最大值为999.99;

char:固定长度字符串类型; char(10) ‘aaa ’ 占10位

varchar:可变长度字符串类型; varchar(10) ‘aaa’ 占3为

text:字符串类型;

blob:字节类型;

date:日期类型,格式为:yyyy-MM-dd;

time:时间类型,格式为:hh:mm:ss

timestamp:时间戳类型 yyyy-MM-dd hh:mm:ss 会自动赋值

datetime:日期时间类型 yyyy-MM-dd hh:mm:ss

//当前数据库中的所有表 SHOW TABLES; //查看表的字段信息 DESC employee; //在上面员工表的基本上增加一个image列。 ALTER TABLE employee ADD image blob; //修改job列,使其长度为60。 ALTER TABLE employee MODIFY job varchar(60); //删除image列,一次只能删一列。 ALTER TABLE employee DROP image; //表名改为user。 RENAME TABLE employee TO user; //查看表格的创建细节 SHOW CREATE TABLE user; //修改表的字符集为gbk ALTER TABLE user CHARACTER SET gbk; //列名name修改为username ALTER TABLE user CHANGE name username varchar(100); //备份表结构和表数据 create table tname2 as select * from tname1; //备份表结构 create table tname2 like tname1; //删除表 DROP TABLE user ; 

3.DML

INSERT

语法: INSERT INTO 表名(列名1,列名2 …)VALUES(列值1,列值2…);

注意:列名与列值的类型、个数、顺序要一一对应。

可以把列名当做java中的形参,把列值当做实参。

值不要超出列定义的长度。

如果插入空值,请使用null

插入的日期和字符一样,都使用单引号括起来。

练习 : create table emp( id int, name varchar(100), gender varchar(10), birthday date, salary float(10,2), entry_date date, resume text ); //插入所有的字段时,可以省略前面的,直接写insert into values();  INSERT INTO emp(id,name,gender,birthday,salary,entry_date,resume) VALUES(1,'zhangsan','female','1990-5-10',10000,'2015-5-5-','good girl'); INSERT INTO emp(id,name,gender,birthday,salary,entry_date,resume) VALUES(2,'lisi','male','1995-5-10',10000,'2015-5-5','good boy'); INSERT INTO emp(id,name,gender,birthday,salary,entry_date,resume) VALUES(3,'你好','male','1995-5-10',10000,'2015-5-5','good boy'); //小知识: //查看数据库编码的具体信息 Show variables like ‘character%; //临时更改客户端和服务器结果集的编码  Set character_set_client=gbk; Set character_set_results=gbk; 

UPDATE:

语法:UPDATE 表名 SET 列名1=列值1,列名2=列值2 。。。 WHERE 列名=值

练习:

//将所有员工薪水修改为5000元。 UPDATE emp SET salary=5000 //将姓名为’zs’的员工薪水修改为3000元。 UPDATE emp SET salary=3000 WHERE name=’ zhangsan’; //将姓名为’aaa’的员工薪水修改为4000元,job改为ccc。 UPDATE emp SET salary=4000,gender='female' WHERE name='lisi'; //将wu的薪水在原有基础上增加1000元。 UPDATE emp SET salary=salary+1000 WHERE gender='male'; //update的if语句,如果性别为m,改为f,否则为m UPDATE user SET sex = IF('m','m','f') 

DELETE:

语法 : DELETE FROM 表名 【WHERE 列名=值】

练习 :

//删除表中名称为’zs’的记录。 DELETE FROM emp WHERE name=‘zs’; //删除表中所有记录。 DELETE FROM emp; //使用truncate删除表中记录。 TRUNCATE TABLE emp; 

DELETE 删除表中的数据,表结构还在;删除后的数据可以找回

TRUNCATE 删除是把表直接DROP掉,然后再创建一个同样的新表。Truncate

删除的数据不能找回。执行速度比DELETE快。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/178958.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月26日 下午4:08
下一篇 2026年3月26日 下午4:08


相关推荐

  • Linux命令:groupadd

    Linux命令:groupaddgroupadd1 作用 groupadd 命令用于将新组加入系统 2 格式 groupadd ggid o r f groupname3 主要参数 ggid 指定组 ID 号 o 允许组 ID 号 不必惟一 r 加入组 ID 号 低于 499 系统账号 f 加入已经有的组时 发展程序退出 4 应用实例建立一个新组 并设置组 ID 加入系统 g

    2026年3月16日
    2
  • Claude-code 使用技巧

    Claude-code 使用技巧

    2026年3月16日
    2
  • 企业联合体的形式_企业联合体「建议收藏」

    企业联合体的形式_企业联合体「建议收藏」企业联合体企业联合体企业联合体定义企业联合体定义::属于经济联合体的一种联合体表现形式(最大经济联合体是欧盟),完全区别于联合公司和战略合作伙伴的联合体,具体是集团公司或者是交叉参股的公司组建的一个企业(联合体)。该联合体应大于两家组建企业。企业联合体职能企业联合体职能::企业联合体可具有独立的法人代表、独立的品牌体系、独立的运作系统,企业联合体也可以是整合资源、共建平台的非独立企业联合体;共同建…

    2025年6月2日
    4
  • Python迭代器实现

    Python迭代器实现文章目录欢迎访问我的个人博客引言 iter 和 next 实现可迭代的斐波那契数列类参考欢迎访问我的个人博客博客引言在 Python 编程中 我们经常使用 for in 语句对容器进行迭代 容器类 比如列表 元组等 之所以可以被 for in 语句迭代 是因为这些容器类实现了 iter 魔术方法 这个方法返回一个迭代器对象 迭代器对象实现了 next 魔术方法 这个方法可以移动迭代器和获取迭代器指向的值 如果我们想要实现支持迭代的对象 只需要实现 iter 方法以及 iter 返

    2025年12月11日
    6
  • XML Schema <第三篇>

    XML Schema <第三篇>

    2021年8月21日
    68
  • 卡巴斯基kav为什么总提示程序已经断开连接「建议收藏」

    卡巴斯基kav为什么总提示程序已经断开连接「建议收藏」用着用着就出现了程序已经断开连接的提示.要求重启产品.请问为什么会这样?该如何解决?这是KIS的一个BUG,我也遇到过。与楼上说的授权啊地震啊都没有关系。下载新版本的KIS就能解决。http://www.kpfans.com/bbs/index.php这是卡巴斯基爱好者论坛,里面有几乎有所有的新旧版本。 

    2022年8月20日
    9

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号