1.现有表A,表A有三个字段啊a,b,c ,表A中存在数据重复数据,请消除重复数据,并针对如何避免重复数据提出建议。mysql
SQL:删除重复数据,只保留一条用SQL语句,删除掉重复项只保留一条在几千条记录里,存在着些相同的记录,如何能用SQL语句,删除掉重复的呢算法
一、查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断 select * from people where peopleId in (select peopleId from people group by peopleId having count(peopleId) > 1)sql
二、删除表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断,只留有rowid最小的记录 delete from people where peopleName in (select peopleName from people group by peopleName having count(peopleName) > 1) and peopleId not in (select min(peopleId) from people group by peopleName having count(peopleName)>1)数据库
三、查找表中多余的重复记录(多个字段) select * from vitae a where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)express
四、删除表中多余的重复记录(多个字段),只留有rowid最小的记录 delete from vitae a where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1) and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)安全
五、查找表中多余的重复记录(多个字段),不包含rowid最小的记录 select * from vitae a where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1) and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1) 服务器
6.消除一个字段的左边的第一位:oracle
update tableName set [Title]=Right([Title],(len([Title])-1)) where Title like '村%'函数
7.消除一个字段的右边的第一位:sqlserver
update tableName set [Title]=left([Title],(len([Title])-1)) where Title like '%村'
8.假删除表中多余的重复记录(多个字段),不包含rowid最小的记录 update vitae set ispass=-1 where peopleId in (select peopleId from vitae group by peopleId,seq having count(*) > 1) and seq in (select seq from vitae group by peopleId,seq having count(*) > 1) and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)
如图片上
1.由于LENGTH()函数 在sql中表明 返回字符长度。11位电话号码、可是前面有个空格。空格也算字符
2.问题:如表1 如何将USERNAME中的大写统一经过update操做改写为小写?
使用lower()函数。如:update QX_USER set USERNAME=lower(USERNAME)
3。问题 判断Xl 中的l是数字仍是字母
若是是sqlserver数据库的话 直接有 ISNUMERIC 函数的
若是输入表达式的计算值为有效的整数、浮点数、money 或 decimal 类型时,ISNUMERIC 返回 1;不然返回 0
若是是ORACLE,能够:
select translate(str,'x1234567890','x') from dual,若是获得的是空则是数字,若是不是空,则是带字符串的。
其实上面这些题都是来考sql语句函数的。
下面是数据库的函数:
oracle经常使用基本函数
经常使用的有单条语句做用的函数:
destinct(去除重复行),
to_char(转换自符串),
to_date(日期格式函数),
sumstr(截取自符串),
lower(将字母转换为小写),
upper(将字母转换为大写),
char(将数字转换为字符),
ascii(求字符的ascii码)等函数;
组函数:min(求最小值),max(求最大值),avg(求平均数),sum(求总和),counnt(统计记录数);
Mysql经常使用基本函数
1、数学函数
ABS(x) 返回x的绝对值
datalength(Char_expr) 返回字符串包含字符字节数,一个汉字为两个字节,如:"abc"=3,“中华人民共和国”=14,“中华人民共和国abc”=17
len(expression)指定字符串或变量名称的长度,中文和英文字母及数字长度均为1,如“中华人民共和国”=7,“abc”=3,“中华人民共和国abc”=10。注意此时不能为length,必须为len
substring(expression,start,length) 很少说了,取子串
right(char_expr,int_expr) 返回字符串右边int_expr个字符
concat(str1,str2,...)返回来自于参数连结的字符串。
字符操做类 :
upper(char_expr) 转为大写
lower(char_expr) 转为小写
UCase(string) 返回 Variant (String),其中包含转成大写的字符串。
LCase(string) 返回字符串的小写形式。
space(int_expr) 生成int_expr个空格
replicate(char_expr,int_expr) 复制字符串int_expr次
reverse(char_expr) 反转字符串
stuff(char_expr1,start,length,char_expr2) 将字符串char_expr1中的从 start开始的length个字符用char_expr2代替
ltrim(char_expr) rtrim(char_expr) 去掉空格
ascii(char) char(ascii) 两函数对应,取ascii码,根据ascii吗取字符
字符串查找 :
charindex(char_expr,expression) 返回char_expr的起始位置
patindex("%pattern%",expression) 返回指定模式的起始位置,不然为0
locate(substr,str,pos) 返回子串substr在字符串str第一个出现的位置
2.数学函数
abs(numeric_expr) 求绝对值
ceiling(numeric_expr) 取大于等于指定值的最小整数
exp(float_expr) 取指数
floor(numeric_expr) 小于等于指定值得最大整数
power(numeric_expr,power) 返回power次方
rand([int_expr]) 随机数产生器
round(numeric_expr,int_expr) 安int_expr规定的精度四舍五入
sign(int_expr) 根据正数,0,负数,,返回+1,0,-1
sqrt(float_expr) 平方根
exp(float x):求e的x次幂
tan(float x):计算x(弧度表示)的正切值。
atan(float x):求x(弧度表示)的反正切值
cos(float x):求x(弧度表示)的余弦值
acos(float x):求x(弧度表示)的反余弦值
sin(float x):计算x(弧度表示)的正弦值。
asin(float x):求x(弧度表示)的反正弦值
fabs(float x):求浮点数x的绝对值
fmod(float x, float y):计算x/y的余数
pow(float x, float y):计算x的y次幂。
sqrt(float x):计算x的平方根。
3.日期,时间函数
getdate() 返回日期
datename(datepart,date_expr) 返回名称
datepart(datepart,date_expr) 取日期一部份
datediff(datepart,date_expr1.dateexpr2) 日期差
dateadd(datepart,number,date_expr) 返回日期加上 number
4.系统函数
suser_name() 用户登陆名
user_name() 用户在数据库中的名字
user 用户在数据库中的名字
show_role() 对当前用户起做用的规则
db_name() 数据库名
object_name(obj_id) 数据库对象名
col_name(obj_id,col_id) 列名
col_length(objname,colname) 列长度
valid_name(char_expr) 是不是有效标识符
5.SQL 合计函数:
Avg 函数:计算包含在特定查询字段中的一组数值的算术平均值。
语法:Avg(expr)expr 表明一个字符串表达式,它或者标识一个字段,该字段包含要计算平均值的数据;或者标识一个表达式,它用该字段中的数据来执行计算。
说明:使用 Avg 计算的平均值是算术平均值(将所有值的总和除以值的数目)。Avg 函数在计算中不计任何 Null 字段。你能够把 Min 和 Max 用于询问表达式和具有 SQL 特性的 QueryDef 对象中或在建立基于 SQL 查询的 Recordset 对象时。
Count 函数:计算从查询返回的记录数。
语法:Count(expr)expr 表明一个字符串表达式,它或者标识一个字段,该字段包含要计算的数据;或者是一个表达式,它使用此字段中的数据来执行计算。expr 中的运算对象可能包括一个表字段名,一个常数或一个函数(多是内在的,也多是用户自定义的,但不是 SQL合计函数).您能够计算任何种类的数据,包含文本数据。
说明:可使用 Count 计算下一级查询的记录数。但 Count 只是简单计算记录的数量。并无论记录中保存的是什么值。Count 函数不数带有 Null 字段的记录。若是 expr 标识多重字段,在至少有一个字段的值不为 Null 的状况下, Count 函数只计算一个记录。若是所有的指定字段为 Null,没有记录会被计算。使用 (&) 分隔字段名。在查询表达式中可使用 Count。你能够把这些表达式应用于具有 SQL特性的 QueryDef对象中或在建立基于SQL查询的Recordset时。
First 和 Last 函数:在查询所返回的结果集中,第一个记录或最后一个记录所返回的字段值。
语法:First(expr);Last(expr)expr 表明一个字符串表达式,它或者标识一个字段,该字段包含要计算的数据;或者是一个表达式,它使用此字段中的数据来执行计算。expr 中的运算对象可能包括一个表字段名,一个常数或一个函数(多是内在的,也多是用户自定义的,但不是 SQL 合计函数)。
说明:First和 Last 函数与 MoveFirst和 MoveLast法在 DAO 记录集合对象中是相近的。它们只简单返回查询结果集中的第一个或最后一个记录的指定字段值。由于一般返回的记录没有必定的顺序 (除非查询中包含一个 ORDER BY 子句),因此这些函数返回的记录会任意地排列。
Min 和 Max 函数:在查询时从一组指定字段的值中返回最小或最大值。
语法:Min(expr);Max(expr) expr 表明一个字符串表达式,它或者标识一个字段,该字段包含要计算的数据;或者是一个表达式,它使用此字段中的数据来执行计算。 expr中的运算对象可能包括一个表字段名,一个常数或一个 函数 (多是内在的,也多是用户自定义的,但不是 SQL 合计函数)。
说明:可使用 Min 及 Max 来计算字段中的最小及最大值,该字段是基于指定的合计或分组的。例如,可使用这些函数返回最低和最高的货运成本。若是没有指定合计,则使用整个表。你可 以把 Avg 用于查询表达式和具有 SQL特性的 QueryDef对象中或当建立基于SQL查询的 Recordset对象时。
StDev 和 StDevP 函数:返回整体或整体样本的标准误差的估计值,此估计值用包含在一个查询的指定字段中的一组值来表示。
语法:StDev(expr);StDevP(expr) expr 表明一个字符串表达式,它或者标识一个字段,该字段包含要计算的数据;或者是一个表达式,它使用此字段中的数据来执行计算。expr 中的运算对象可能包括一个表字段名,一个常数或一个函数(多是内在的,也多是用户自定义的,但不是 SQL 合计函数)。
说明:StDevP 函数计算整体,而 StDev 函数则计算整体样本。若是下一级查询中包含两个如下的记录(或没有记录,对于StDevP 函数),这两个函数将返回一个 Null 值(表示不能计算标准误差)。能够在查询表达式中使用 StDev 和 StDevP 函数。你能够把这些表达式应用于具有 SQL 特性的 QueryDef 对象中或在建立基于 SQL 查询的Recordset 时。
Sum 函数:返回包含在指定查询字段中一组值的总计。
语法:Sum(expr) expr 表明一个字符串表达式,它或者标识一个字段,该字段包含要计算的数据;或者是一个表达式,它使用此字段中的数据来执行计算。 expr中的运算对象可能包括一个表字段名,一个常数或一个函数(多是内在的,也多是用户自定义的,但不是 SQL 合计函数)。
说明:Sum 函数求字段中值的总和。例如,可用 Sum 函数计算货运的总费用。Sum 函数会忽略包含 Null 字段的记录。下列示例显示如何计算产品的 UnitPrice (单价)及 Quantity (数量)字段的合计:
SELECT
Sum(UnitPrice * Quantity)
AS [Total Revenue] FROM [Order Details];
能够在一个查询表达式之中使用 Sum 函数。你也能够在具有 SQL 特性的 QueryDef 对象中或在建立基于SQL查询的 Recordset 对象时使用这一表达式。
Var 和 VarP 函数:返回一个整体或整体样本的方差的估计值,此估计值用包含在指定查询字段中的一组值来表示。
语法:Var(expr);VarP(expr) expr 表明一个字符串表达式,它或者标识一个字段,该字段包含要计算的数据;或者是一个表达式,它使用此字段中的数据来执行计算。expr 中的运算对象可能包括一个表字段名,一个常数或一个函数(多是内在的,也多是用户自定义的,但不是 SQL 合计函数)。
说明:使用 VarP 函数计算整体,而 Var 函数计算整体样本。若是下一级查询中包含两个如下的记录,Var 及 VarP 函数将返回一个 Null 值,该表示不能计算方差。在查询表达式或 SQL 语句中,可使用 Var 及 VarP 函数。