В сочетании PHP и MySQL двойные кавычки и одинарные кавычки значительно упрощают время написания запросов.
$query = "INSERT INTO `table` (`id`, `col1`, `col2`) VALUES (NULL, '$val1', '$val2')";
Теперь предположим, что вы используете прямую переменную post в MySQL-запросе, тогда используйте ее следующим образом:
$query = "INSERT INTO `table` (`id`, `name`, `email`) VALUES (' ".$_POST['id']." ', ' ".$_POST['name']." ', ' ".$_POST['email']." ')";
Это лучшая практика для использования переменных PHP в MySQL.
см. это:
Как узнать, что мое приложение для Android было обновлено, чтобы сбросить тревогу?
Исправлено исправление: вы используете неправильная строка в манифесте: http://developer.android.com/reference/android/content/Intent.html#ACTION_PACKAGE_REPLACED
это должно быть «android.intent.action .PACKAGE_REPLACED ".
ok, я вижу, что того, что я написал, все еще недостаточно, чтобы попробовать, поэтому я сделаю исключение и опубликую целый проект, чтобы показать, что это works: код приложения находится в пакете под названием «com.broadcast_receiver_test». не забудьте запустить его перед тестированием, иначе он не будет работать на некоторых версиях Android (я думаю, API 11+).
манифест:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.broadcast_receiver_test" android:versionCode="1"
android:versionName="1.0">
<uses-sdk android:minSdkVersion="3" />
<application android:icon="@drawable/ic_launcher"
android:label="@string/app_name">
<activity android:name=".BroadcastReceiverTestActivity"
android:label="@string/app_name">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<receiver android:name=".MyBroadcastReceiver">
<intent-filter>
<action android:name="android.intent.action.PACKAGE_REPLACED"/>
<data android:scheme="package" />
</intent-filter>
<intent-filter>
<action android:name="android.intent.action.PACKAGE_REMOVED"/>
<data android:scheme="package" />
</intent-filter>
<intent-filter>
<action android:name="android.intent.action.PACKAGE_ADDED"/>
<data android:scheme="package" />
</intent-filter>
</receiver>
</application>
</manifest>
MyBroadcastReceiver. java:
public class MyBroadcastReceiver extends BroadcastReceiver
{
@Override
public void onReceive(final Context context,final Intent intent)
{
final String msg="intent:"+intent+" action:"+intent.getAction();
Log.d("DEBUG",msg);
Toast.makeText(context,msg,Toast.LENGTH_SHORT).show();
}
}
просто запустите его и убедитесь, что он отлично работает.
EDIT: если ваше приложение предназначено для API12 и выше, и вы хотите обработать в случае обновления вашего приложения вы можете использовать это намерение самостоятельно:
http://developer.android.com/reference/android/content/Intent.html#ACTION_MY_PACKAGE_REPLACED
Я разместил следующий приемник в AndroidManifest.xml
<receiver android:name=".StartupReceiver">
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED"/>
</intent-filter>
<intent-filter>
<action android:name="android.intent.action.MY_PACKAGE_REPLACED"/>
</intent-filter>
</receiver>
. Мое приложение может быть запущено при обновлении, а также перезагрузка устройства. Конечно, каждый упомянул, что вам нужен API 12+ для MY_PACKAGE_REPLACED.