java数据库 四 .Sql的分类

本文详细介绍了Sql的四大分类:DDL(数据定义语言)、DML(数据操作语言)、DCL(数据控制语言)和DQL(数据查询语言)。重点讲解了DDL中的数据库和表的操作,包括创建、查询、修改和删除。DML部分详细阐述了插入、更新和删除操作,提供了丰富的实例。同时,还探讨了DQL查询语言的基础用法,如基础查询、条件查询、模糊查询和排序等。
摘要由CSDN通过智能技术生成

四、Sql的分类

                     DDL(*)(Data Definition Language):数据定义语言,用来定义数据库对象:库、表、列等;

                     DML(**)(Data Manipulation Language):数据操作语言,用来定义数据库记录(数据);

                     DCL(Data Control Language):数据控制语言,用来定义访问权限和安全级别;

                     DQL(*****)(Data Query Language):数据查询语言,用来查询记录(数据)。

* 注意:sql语句以;结尾

4.1 DDL:操作数据库、表、列等

使用的关键字:CREATE ALTER DROP

* 4.1.1操作数据库

              创建

                            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;

* 4.1.2操作数据表

       * 语法:

                     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);

删除表

DROP TABLE user ;

4.2 DML操作(重要)

查询表中的所有数据

SELECT * FROM 表名;

DML是对表中的数据进行增、删、改的操作。不要与DDL混淆了。

INSERT UPDATE DELETE

小知识:

mysql中,字符串类型和日期类型都要用单引号括起来。

空值:null

4.2.1插入操作: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 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');

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: java.util.Date是Java提供的日期和时间的类,它包含了日期和时间的信息。它可以表示从1970年1月1日00:00:00以来经过的毫秒数。由于java.util.Date是不可变的类,因此它的操作非常有限。 而java.sql.Date是java.util.Date的一个子类,它是专门用于操作数据库中日期类型数据的类。java.sql.Date继承了java.util.Date的大部分方法,但是它只保存年月日的信息,不包含具体的时分秒。java.sql.Date可以通过java.sql包提供的接口和类与数据库交互。 因为java.sql.Date是专为数据库而设计的,它有很多特定的用法。比如可以将java.sql.Date从数据库中读取出来,并用作Java程序中的日期类型。此外,它还可以将Java程序中的日期类型转换为数据库中的日期类型,方便进行数据库操作。 总的来说,java.util.Date是Java中常用的日期和时间类型,而java.sql.Date是专为数据库设计的日期类型,在与数据库交互时非常有用。 ### 回答2: java.util.Date是Java中的一个类,它表示一个特定的时间点,包括年、月、日、时、分、秒等信息。它用于表示一个精确到毫秒的时间点,并且它没有与时区相关的信息。在使用java.util.Date时,我们可以通过构造方法设置指定的年月日时分秒,也可以使用现有的时间点创建对象。 java.sql.Date是java.util.Date的一个子类,用于在Java程序和数据库之间传递日期数据。它继承了java.util.Date的基本功能,同时还提供了一些用于处理数据库日期的特定方法。在Java中,java.sql.Date可以通过使用java.util.Date进行实例化,或者通过调用java.sql.Date的构造方法指定年月日。 java.util.Date和java.sql.Date在功能上有着一些区别。首先,java.util.Date中包含的时间信息更加详细,可以表示年、月、日、时、分、秒、毫秒等。而java.sql.Date只包含年、月、日的信息,没有时分秒。其次,java.util.Date可以用于处理任意的时间点,而java.sql.Date只能用于处理日期,时间部分会被忽略。另外,由于java.sql.Date主要用于数据库交互,它具有特定的格式,可以与数据库中的日期字段进行交互。 在实际应用中,我们通常使用java.util.Date来表示一个具体的时间点,比如记录日志的时间、定时任务的执行时间等。而在与数据库交互时,我们可以使用java.sql.Date来传递、存储和检索日期数据。 ### 回答3: java.util.Date和java.sql.Date都是Java中用于表示日期和时间的类,但在使用上有一些区别。 java.util.Date是Java中最基本的日期和时间类,它包含了日期和时间的信息,可以表示从1970年1月1日00:00:00开始的时间戳。它可以表示精确到毫秒级别的时间,但是在处理日期和时间的各种操作时,它的功能相对较弱,需要借助其他类库进行处理。在Java 8之后,java.util.Date已经被废弃,推荐使用新的日期和时间API(java.time包)。 java.sql.Date是java.util.Date的一个子类,它用于在Java数据库之间传递日期。它的底层实现是基于long类型的时间戳,但它对应的数据库类型是SQL中的DATE类型,只包含日期部分,不包含具体的时间信息。它的使用场景通常是在与数据库交互的过程中,需要将日期信息保存到数据库或从数据库中获取日期信息。 在实际使用中,如果我们需要进行日期和时间的大部分操作,推荐使用新的日期和时间API(java.time包),例如LocalDate、LocalTime和LocalDateTime等类,它们提供了更多的功能和操作,而且更易于使用和理解。而对于与数据库交互时,如果数据库的数据类型是DATE类型,我们可以使用java.sql.Date来表示和传递日期信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值