首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

SQL函数 USER

SQL函数 USER返回当前用户的用户名的函数。大纲USER{fn USER}{fn USER()}描述USER 不接受任何参数并返回当前用户的用户名(也称为授权 ID)。...通用函数不允许括号; ODBC 标量函数可以指定或省略空括号。用户名是使用 CREATE USER 命令定义的。USER 的典型用途是在 SELECT 语句选择列表或查询的 WHERE 子句中。...在设计报告时,USER 可用于打印正在为其生成报告的当前用户。...示例以下示例返回当前用户名:SELECT USER AS CurrentUseryx以下示例选择姓氏 ($PIECE(Name,',',1) 或名字(没有中间首字母)与当前用户名匹配的那些记录:SELECT...Name FROM Sample.Person WHERE %SQLUPPER(USER)=%SQLUPPER($PIECE(Name,',',1)) OR %SQLUPPER(USER)=%SQLUPPER

42320
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQLUSER()和CURRENT_USER()的区别

    USER()和CURRENT_USER()的一点不同 某次在用 ALTER USER 想要修改账户密码时,发现执行下面的SQL会报语法错误: mysql> ALTER USER USER() IDENTIFIED...,如果把 USER() 手动替换成对应的账户的话,则可以正常执行: mysql> ALTER USER test@'%' IDENTIFIED WITH ......Query OK, 0 rows affected (0.10 sec) 看来是修改密码时不能调用 USER() 函数,但可以用 CURRENT_USER() 函数,那么这两个函数的区别是什么呢?...这么说可能还有点疑惑,看下面的案例吧: # 有一个授权账户是 yejr@'%' mysql> SELECT HOST,USER FROM mysql.user WHERE user='yejr'; +-...这样就可以解释一开始的问题了,为什么不能在修改密码时调用 USER() 函数,而只能用 CURRENT_USER() 函数了。

    96530

    PHP 中 call_user_func 函数 和 call_user_func_array 函数的区别

    PHP 中 call_user_func() 函数 和 call_user_func_array() 函数都是回调函数,在写接口的时候经常会用到,但是他们有什么区别呢?...它们的第一个参数都是被调用的回调函数,call_user_func() 还可以有多个参数,它们都是回调函数的参数,call_user_func_array() 只有两个参数,第二个参数是要被传入回调函数的数组...所以它们最大的区别就是: 如果传递一个数组给 call_user_func_array(),数组的每个元素的值都会当做一个参数传递给回调函数,数组的 key 回调掉。...如果传递一个数组给 call_user_func(),整个数组会当做一个参数传递给回调函数,数字的 key 还会保留住。...个参数:"; echo " "; print_r($args); echo " "; } 然后我们分别使用 call_user_func 函数 和 call_user_func_array

    40130

    Navicat mysql报错 1142 – SELECT command denied to user ‘xxx‘@‘localhost‘ for table ‘user

    主机上的MYSQL可以有很多个数据库,这个MYSQL有一个root账户,这个账户可以随意操作其他数据库账户的权限。...这里的问题就在于user1的权限不足,我们就需要用root赋予user1更大的权限。 那么root账号是啥,密码又是啥?...//切换到D盘盘符 C:\Users\Administrator>D: //切换到MYSQL目录下,目录获取方法请看上一步骤 D:\>cd D:\BtSoft\WebSoft\mysql\MySQL5.5...\bin //用root登陆MYSQL,指令:mysql -hlocalhost -uroot -p密码 D:\BtSoft\WebSoft\mysql\MySQL5.5\bin>mysql -hlocalhost...//不清楚这是干啥的(滑稽 mysql> use mysql Database changed //输出用户名为sql_dora的信息 mysql> select * from user where user

    3.1K30

    mysql报错 1142 – SELECT command denied to user ‘root_ssm’@’localhost’ for table ‘user’「建议收藏」

    错误信息的字面意思是:表“user”拒绝用户“root_ssm”@“localhost”的SELECT命令 ,很明显用户没有查看user表的权限,用管理员账号给他授权就行了 一、使用客户端授权(Navicat...Premium 12) 1、使用root用户登陆mysql 2、新建查询,输入指令: use mysql; select * from user where user=’root_ssm’; SQL...二、使用Mysql的命令行客户端 1、root用户登陆mysql 2、查看’root_ssm’用户的信息 use mysql; select * from user where user='root_ssm...3、修改root用户的localhost权限 update user set Select_pri='Y' where user='root_ssm' 根据查询结果中的列名,一个一个的写update语句修改..., 全部改好后再刷新MySQL的系统权限相关表: flush privileges; 4、修改好后查看表信息 之后重启mysql服务,权限就都有了。

    6.7K20

    Mysql The user specified as a definer (test@%) does not exist

    我们再用user1进行登陆: mysql> use testdb; Database changed mysql> call user_count(); ERROR 1142 (42000): SELECT...,存储过程执行过程中会以user1具有的权限来执行,其中调用到了mysql的库,而我们的user1帐户只有testdb库的使用权限,所以会返回失败。...='user_count'; 再次用user1进行登陆: mysql> use testdb; Database changed mysql> call user_count(); +--------...由于前期在测试库上开发的缘故,我们经常定义到的definer为`root`@`%`,后来搬移到生产库上又得改回来,存在着大量的更新,上百个的视图,函数等一个个改不免太麻烦并且也可能遗漏。...1.修改function、procedure的definer select definer from mysql.proc; -- 函数、存储过程 update mysql.proc set definer

    2K10

    关于MySQL DNS解析探究之二:unauthenticated user

    把这篇没写完的文章写完,2015年的事就不留到2016了 开启DNS解析 mysql> show variables like 'skip_name_resolve'; +---------------...----------------+-------+ 通过代码模拟用户查询请求,不断的建立连接执行sql查询,然后通过show processlist命令查看连接情况: JAVA代码一 /** * MySQL...16.242444797905648 median: 12.0 skewness: 20.270437547223214 kurtosis: 463.94461541900915 发现最大值421ms mysql...skewness: 20.655330340756084 kurtosis: 471.9124123214076 对比上一次开启DNS解析,这次的结果性能有所提高,上一次的均值是14ms,这次为10ms mysql...的用户 目前可得出如下结论: DNS解析确实会影响连接建立的性能,但是DNS解析开启与否,与出现unauthenticated user没有关系 猜想unauthenticated user的出现应该是连接在建立的过程中出现的临时状态

    1.3K80

    mysql分区函数_mysql 分区可用函数

    ) SECOND() TIME_TO_SEC() TO_DAYS() WEEKDAY() YEAR() YEARWEEK() 等 当然,还有FLOOR(),CEILING() 等,前提是使用这两个分区函数的分区健必须是整型...EXPLAIN PARTITIONS跟踪发现都是全区扫描的,条件里加入WEEKDAY(visittime)这样的也不行 但是如果你插入的datetime字段是不带时间只有日期的话,where条件里没出现函数只用...=来判断日期,是可以分区搜索的 分区应该和索引一样,一但where中出现函数,就会全区扫描 下面的表PARTITION BY LIST (month(create_time)),Explain结果不太乐观...mysql> Explain partitions select * from rec_pay where create_time = ‘2014-06-01 00:00:00’ limit 20;...时发生 range:这个连接类型使用索引返回一个范围中的行,比如使用>或 index:以索引的顺序进行全表扫描,优点是不用排序,缺点是还要全表扫描 ALL:全表扫描,应该尽量避免 8 Extra:关于MYSQL

    5.8K10
    领券