Можно использовать функции НИЖЕ () или LCASE ().
Они могут использоваться оба на столбцах или строковых литералах. например,
SELECT LOWER(column_name) FROM table a;
или
SELECT column_name FROM table a where column = LOWER('STRING')
LCASE () можно заменить НИЖЕ () в обоих примерах.
Если вы используете PHP 5.3.0 или выше, вы можете использовать следующее:
$classname::$$propertyname;
К сожалению, если вы используете версию ниже 5.3.0, вы застряли при использовании eval ()
( get_class_vars ()
не будет работать, если значение динамическое).
$value = eval($classname.'::$'.$propertyname.';');
EDIT: Я только что сказал get_class_vars ()
не будет не работает, если значение динамическое, но очевидно, что статические члены переменных являются частью «свойств класса по умолчанию» . Вы можете использовать следующую оболочку:
function get_user_prop($className, $property) {
if(!class_exists($className)) return null;
if(!property_exists($className, $property)) return null;
$vars = get_class_vars($className);
return $vars[$property];
}
class Foo { static $bar = 'Fizz'; }
echo get_user_prop('Foo', 'bar'); // echoes Fizz
Foo::$bar = 'Buzz';
echo get_user_prop('Foo', 'bar'); // echoes Buzz
К сожалению, если вы хотите установить значение переменной, вам все равно придется использовать eval ()
, но с некоторой проверкой на месте это не так уж плохо .
function set_user_prop($className, $property,$value) {
if(!class_exists($className)) return false;
if(!property_exists($className, $property)) return false;
/* Since I cannot trust the value of $value
* I am putting it in single quotes (I don't
* want its value to be evaled. Now it will
* just be parsed as a variable reference).
*/
eval($className.'::$'.$property.'=$value;');
return true;
}
class Foo { static $bar = 'Fizz'; }
echo get_user_prop('Foo', 'bar'); // echoes Fizz
set_user_prop('Foo', 'bar', 'Buzz');
echo get_user_prop('Foo', 'bar'); // echoes Buzz
set_user_prop ()
с этой проверкой должен быть безопасным. Если люди начнут помещать случайные вещи как $ className
и $ property
, он выйдет из функции, поскольку это не будет существующий класс или свойство. Что касается $ value
, он никогда не анализируется как код, поэтому все, что они туда помещают, не влияет на сценарий.
Вы должны быть в состоянии сделать что-то вроде:
eval("echo $classname::$propertyname;");
Я только что сделал быстрый тест и заставил это работать для меня. Не уверен, есть ли способ получше, но мне не удалось его найти.
«eval» так похож на «зло», и я ненавижу его использовать и / или видеть его в коде. С несколькими идеями из других ответов, вот способ избежать этого, даже если ваш php не 5,3 или выше.
Изменено, чтобы отразить тестирование на основе комментария.
class A {
static $foo = 'bar';
}
A::$foo = 'baz';
$a = new A;
$class = get_class($a);
$vars = get_class_vars($class);
echo $vars['foo'];
Выводит "baz".
Потенциально актуально: обсуждение позднего статического связывания в PHP - Когда вам нужно использовать позднее статическое связывание? .
get_class_vars
не то же самое, что get_object_vars
.
Я думаю, что get_clas_vars
должен возвращать исходные значения свойств.
Одно я заметил, что нельзя задавать переменные, которые защищены в статических классах, так как команда eval() выполняется в области видимости вне класса. Единственное, что можно обойти, это реализовать статический метод внутри/всех классов, которые запускают eval(). Этот метод можно было бы защитить, так как call_user_func() [для вызова метода setter] также выполняется изнутри класса.
Я думаю, это самый простой:
$foo = new ReflectionProperty('myClassName', 'myPropertyName');
print $foo->getValue();