SQL语句如何统计数据库当日信息数量

SQL语句如何统计数据库当日信息数量,第1张

你说的当日是指某一天吗?首先你的时间字段的类型必须是datetime类型,如果不是就转换一下。

查询语句可以这样写,假设我们要查询2006年6月1日这一天的数据量。我不知道你的时间字段是不是datetime类型,所以进行了转换。

select count()

from 表

where convert(varchar(8),cast(时间字段 as datetime),112)='20060601'

把“表”和“时间字段”替换成实际的名称就可以了

--查询所有用户定义表

select  from sysobjects Where type='U' And type_desc='USER_TABLE'

--用户定义表个数

select Count(0) as '用户定义表的个数' from sysobjects Where type='U' And type_desc='USER_TABLE'

sysobject是系统表,记录用户创建了哪些对象,这个表里会存:表、索引、存储过程、函数

不过sysobject只有08及其以后的版本才支持,05及以前的版本都是用的Sysobjects

名字差不多,性质一样

数据库ProjectsA中的表数量写上完全限定名就好了

ProjectsAsyssysobjects,其他的和之前一样

select  from ProjectsAsyssysobjects Where type='U' And type_desc='USER_TABLE'

select Count(0) from ProjectsAsyssysobjects Where type='U' And type_desc='USER_TABLE'

至于status的作用,看这里

>

今天主要复习了MySQL的一些简单语句,可总结:

mysql 统计 表的数量:SELECT COUNT(1) FROM information_schemaTABLES WHERE TABLE_SCHEMA = '你的数据库';

有时候需要查询MySQL数据库中各个表大小,该如何 *** 作呢?

MySQL中有一个名为 information_schema 的数据库,在该库中有一个 TABLES 表,这个表主要字段分别是:

TABLE_SCHEMA : 数据库名

TABLE_NAME:表名

ENGINE:所使用的存储引擎

TABLES_ROWS:记录数

DATA_LENGTH:数据大小

INDEX_LENGTH:索引大小

use information_schema;

SELECT

TABLE_NAME,

(DATA_LENGTH/1024/1024) as DataM ,

(INDEX_LENGTH/1024/1024) as IndexM,

((DATA_LENGTH+INDEX_LENGTH)/1024/1024) as AllM,

TABLE_ROWS

FROM

TABLES

WHERE

TABLE_SCHEMA = '你的数据库';

MySQL的一些基础语句:

行是记录 列是字段

创建库

CREATE DATABASE [IF NOT EXISTS] 数据库名 [参数[ 参数] [ 参数]];

参数:

CHARACTER SET 码表名

COLLATE 校对规则名, 详见文档10101

显示库

SHOW DATABASES;

显示数据库创建语句

SHOW CREATE DATABASE 数据库名;

修改库

ALTER DATABASE 数据库名[ 参数[ 参数][ 参数]];

注意: 不能改数据库的名字

删除库

DROP DATABASE [IF EXISTS] 数据库名;

*** 作表之前使用需要先确定使用哪个数据库

USE 数据库名

创建表

CREATE TABLE 表名(列名 类型[,列名 类型][,列名 类型]);

查看所有表

SHOW TABLES;

查看表的创建语句

SHOW CREATE TABLE 表名;

显示表结构

DESC 表名;

修改表名

RENAME TABLE 原表名 TO 新表名;

修改字符集

ALTER TABLE 表名 CHARACTER SET 字符集名;

删除表

DROP TABLE 表名;

追加列

ALTER TABLE 表名 ADD 列名 类型[,列名 类型][,列名 类型];

修改列类型

ALTER TABLE 表名 MODIFY 列名 类型[,列名 类型][,列名 类型];

修改列

ALTER TABLE 表名 CHANGE COLUMN 原列名 新列名 类型;

删除列

ALTER TABLE 表名 DROP 列名;

插入语法:

INSERT INTO 表名[(列名[,列名])] VALUES(值[,值]);

注意事项:

插入值类型必须与对应列的数据类型一致

数据不能超出长度

插入值得为之必须与列名顺序一致

字符和日期数据要放在单引号中

插入空值使用null

如果不指定插入哪一列, 就是插入所有列

中文数据

由于默认码表是utf8, 而cmdexe的码表是gbk, 在插入中文数据的时候会报错, 所以我们需要修改客户端码表

先查看系统变量: SHOW VARIABLES LIKE 'character%';

修改客户端码表: SET character_set_client=gbk;

修改输出数据的码表: SET character_set_results=gbk;

修改语法

UPDATE 表名 SET 列名=值[,列名=值][WHERE 条件语句];

注意事项

WHERE子句选择满足条件的行进行更新, 如果不写, 则更新所有行

删除语法

DELETE FROM 表名 [where 条件语句]

注意事项

如果不加where子句, 将删除表中所有记录

delete只能用作删除行, 不能删除某一列的值, 需要用update

在delete和update的时候需要注意表与表之间的关联关系

删除表中所有数据可以使用: TRANCATE 表名, 这种方式会删除旧表重新创建, 在数据较多的时候使用

备份数据库

输入quit退出mysql, 在cmdexe中输入:

mysqldump –u用户名 –p密码 数据库名 > 文件名

恢复数据库

进入mysqlexe之后, 使用数据库之后

source 文件名

*** 作数据(查询)

DISTINCT语法

SELECT [DISTINCT] 列名[, 列名] FROM 表名

注意事项

可以替代列名, 表示所有列, 但是通常我们为了提高代码的可读性, 不使用

DISTINCT为过滤重复记录

如果DISTINCT后面跟多列, 是过滤掉多列合并之后的重复

列名表达式——语法

SELECT 列名|表达式[,列名|表达式] FROM 表名

注意事项

表达式只是显示时起作用, 不会改变数据库中的值

AS——

SELECT 列名 AS 别名 FROM 表名

注意事项

起别名时AS可以省略

不会改变数据库中的值

WHERE——

语法

SELECT 列名 FROM 表名 [WHERE 条件语句]

WHERE子句中的运算符

比较运算符

>, <, >=, <=, =, <>

注意不等于和Java中不同, 是<>

BETWEEN AND

某一区间内的值, 从 到

IN(列表)

在列表之中, 例: in(1,2,3) 代表1或2或3

LIKE(表达式)

模糊查询, %代表多个字符, _代表单个字符

IS NULL

判断是否为NULL

逻辑运算符

AND &&

与, 两边都为TRUE结果为TRUE

OR ||

或, 一边为TRUE结果就为TRUE

NOT !

非, 将表达式结果取反

ORDER BY——

语法

SELECT 列名 FROM 表名 ORDER BY 列名 ASC|DESC;

注意事项

ORDER BY 指定排序的列名可以是表中的列名, 也可以是SELECT语句后面起的别名

ASC为升序, DESC为降序

ORDER BY应在查询语句的结尾

COUNT函数——

语法

SELECT COUNT()|COUNT(列名) from 表名 [WHERE 条件语句]

注意事项

COUNT(列名)的方式是统计指定列中有多少条记录, 不包括值为NULL的

COUNT()则是统计表中有多少条数据

COUNT(DISTINCT 列名) 统计不重复的记录数

如果加上WHERE子句, 则是统计满足条件的记录

select from dba_users; 查看数据库里面所有用户,前提是你是有dba权限的帐号,如sys,system

select from all_users; 查看你能管理的所有用户!

select from user_users; 查看当前用户信息 !

-- 查询你 当前用户下,有哪些表

SELECT FROM user_tables

-- 查询你 当前用户下, 可以访问哪些表 [也就是访问自己 和 其他用户的]

SELECT FROM all_tables

-- 查询当前数据库所有的表, 需要你有 DBA 的权限

SELECT FROM dba_tables

mysql 50

show databases;//显示所有数据库名

use databasename;//选择一个数据库

show tables;//显示所有数据表

记录集的recordcount属性就是根据记录集条件返回的记录总数

比如:

sql = "select from tj"

Set rs = connexecute(sql)

Responsewrite "数据表的中的记录条数是:" & rsrecordcount

select count(table_name) from user_tables;

这条语句后面还可以根据需要添加条件,例如用户名,表空间名等等。

希望能够满足你的要求,期待成为最佳答案。O(∩_∩)O~

如果使用String sqlQuery = "SELECT FROM table";

的话,可以使用ResultSet的getRow

(1)首先使用last()方法,将数据库游标定位到记录集的最后一行。

(2)使用getRow()方法,返回记录集最后一行的行索引。该索引就等于记录集所包含记录的个数,也就是记录集的行数。getRow()方法是在JDBC API 20中才定义的,在JDBC API 10中没有这个方法。

----------------------

SELECT count() FROM table 的话,直接从resultset中获取

rsgetInt(1);

以上就是关于SQL语句如何统计数据库当日信息数量全部的内容,包括:SQL语句如何统计数据库当日信息数量、SqlServer查询某个数据库中表的数量、mysql快速查询数据库中有多少条数据等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9750583.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-01
下一篇2023-05-01

发表评论

登录后才能评论

评论列表(0条)

    保存